标题:[求助]Hibernate如何解决多条件进行模糊查询?
只看楼主
limaoyuan
Rank: 1
等 级:新手上路
帖 子:493
专家分:0
注 册:2006-6-25
 问题点数:0 回复次数:2 
[求助]Hibernate如何解决多条件进行模糊查询?

Criteria.add(Example.create(Object entity)) //据说这个方法可以,可我试了,不太成,如有五个条件,只填了其中的三条进行查
询,刚查不出结果。

除拼接HQL以外,还有没有什么好的解决办法!

多谢!
搜索更多相关主题的帖子: Hibernate 条件 模糊 Criteria 
2007-09-16 21:19
limaoyuan
Rank: 1
等 级:新手上路
帖 子:493
专家分:0
注 册:2006-6-25
得分:0 
给个能实现的具体的例子也行,谢谢了

我在说's blog   http://www..cn
2007-09-16 21:26
ningkun
Rank: 1
等 级:新手上路
帖 子:24
专家分:0
注 册:2007-9-15
得分:0 
/**
* 根据条件查询
*/
public List byStudent(String sno,String sname,String address,int classid){

Criteria critera = getSession().createCriteria(Student.class);//里面是一个class对象,而不是HQL
if(sno!=null&&!sno.equals("")){//如果equals在前面的话,容易报 nullpoint 异常
critera.add(Restrictions.like("sno", sno,MatchMode.ANYWHERE));
//如果是进行模糊查询的话,就要加一个参数,MatchMode.ANYWHERE ,否则就不能进行模糊查询
}
if(sname!=null&&!sname.equals("")){
critera.add(Restrictions.like("sname", sname,MatchMode.ANYWHERE));
}
if(address!=null&&!address.equals("")){
critera.add(Restrictions.like("address", address,MatchMode.ANYWHERE));
}
if(classid!=0){
critera.add(Restrictions.eq("classes.cid",new Integer(classid)));
}
return critera.list();
}

共同学习,共同进步,呵呵!
2007-09-16 22:49



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-170426-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.052481 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved