您的位置:首页 > 其它

hibernate criteria的使用

2011-12-15 10:38 447 查看
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方法加入。

表达式对象的方法有:

方法
描述
Expression.eq
对应SQL的“field=value”表达式
如:Expression.eq(“name”,”zx”);
Expression.allEq
方法的参数为一个Map类型对象,包含多个名/值对对应关系,相当于多个Expression.eq的叠加
Expression.gt
对应SQL的“field>value”表达式
Expression.ge
对应SQL的“field>=value”表达式
Expression.lt
对应SQL的“field”表达式
Expression.le
对应SQL的“field<=value”表达式
Expression.between
对应SQL语句的between表达式,如:查询年龄在2127岁之间的用户,可以写成Expression.between(“age”,new
Integer(21),new Integer(27));

Expression.like
对应SQL语句的”field like value”表达式
Expression.in
对应SQL语句的“field in(……)”表达式
Expression.eqProperty
用于比较两个属性值,对应”field=field”SQL表达式
Expression.gtProperty
用于比较两个属性值,对应”field>field”SQL表达式
Expression.geProperty
用于比较两个属性值,对应”field>=field”SQL表达式
Expression.ltProperty
用于比较两个属性值,对应”field表达式
Expression.leProperty
用于比较两个属性值,对应”field<=field”SQL表达式
Expression.and
对应SQL语句的And关系组合,如:Expression.and(Expression.eq(“name”,”zx”),Expression.eq(“sex”,”1”));
Expression.or
对应SQL语句的Or关系组合,如:Expression.or(Expression.eq(“name”,”zx”),Expression.eq(“name”,”zhaoxin”));
Expression.sql
作为补充这个方法提供了原生SQL语句查询的支持,在执行时直接通过原生SQL语句进行限定,如:Expression.sql(“lower({alias}.name)
like (?)”,“zhao%”,Hibernate.STRING) ;
在运行时{ alias }将会由当前查询所关联的实体类名替换,()中的?将会由”zhao%”替换,并且类型由Hibernate.STRING指定。
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();
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: