Criteria 笔记

    技术2022-05-11  8

    来自:徽骆驼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


    最新回复(0)