来自:徽骆驼Criteria Query 可以看作传统sql的对象化表示
Criteria 可以由session创建Criteria ct= session.createCriteria(TUser.class);
Criteria中可以增加查询条件ct.add(Expression.eq("name","Erica"));ct.add(Expression.eq("sex",new Integer(1)));
Criteria中增加的查询条件可以由表达式对象创建Expression.eq(对象属性名,对象属性值);
查询条件通过Criteria的add方法加入。
表达式对象的方法有:eq 等于,第一个参数是对象属性,第二个参数是值allEq 参数为一个Map对象,相当于多个eq的叠加gt 大于ge 大于等于lt <le <=between 在两个值之间Expression.between("age",new Integer(10),new Integer(20));like like查询in in查询eqProperty 用于比较两个对象的属性的值是否相等gtProperty gePropertyltPropertylePropertyand and方法可以嵌套Expression对象,用于and关系or 同上 如:Expression.or( Expression.eq("name","hulei"), Expression.eq("name","jane") );sql 作为Expression对象的补充,本方法提供对原生sql的支持
***注意,在Hibernate3中,引入了Restrictions类作为Expression的替代,以后的版本,不再推荐使用Expression。***但是,Restrictions类的使用方法和Expression的方法一致。
注意,在查询条件中,Hibernate提供了一个Example查询,当查询条件比较多的时候,可以用Example查询来简化代码,使用方法如下:TUser user=new TUser();user.setLoginName("hulei");user.setPassword("hulei");Criteria ct=session.createCriteria(TUser.class);ct.add(Example.create(user));return ct.list();
复合查询Criteria查询可以嵌套Criteria来实现复合查询如下:Criteria ct=session.createCriteria(TUser.class);Criteria ctAddress=ct.createCriteria("addresses");//这里是嵌套了一个Criteria查询,这里的addresses是TUser的属性ctAddress.add(Expression.like("address","%shanghai%"));List list=ct.list();
http://www.blogjava.net/shichengjun1984/archive/2007/09/24/147793.html
