criteria用法
来源:互联网 发布:2016年网络关键词 编辑:程序博客网 时间:2024/05/17 01:05
Criteria Query通过面向对象化的设计,将数据查询条件封装为一个对象。简单来讲,Criteria Query可以看作是传统SQL的对象化表示,如:
- Criteria criteria = session.createCriteria(User.class);
- criteria.add(Expression.eq("name","Erica"));
- criteria.add(Expression.eq("sex",new Integer(1)));
Criteria 查询表达式
Criteria 本身只是一个查询容器,具体的查询条件需要通过Criteria.add方法添加到Criteria实例中。 如前例所示,Expression 对象具体描述了查询条件。针对SQL 语法,Expression提供了对应的查询限定机制,包括:
- Expression.eq 对应SQL“field = value”表达式。 如Expression.eq("name","Erica")
- Expression.allEq 参数为一个Map对象,其中包含了多个属性-值对应关系。相当于多个Expression.eq关系的叠加。
- Expression.gt 对应SQL中的 “field > value ” 表达式
- Expression.ge 对应SQL中的 “field >= value” 表达式
- Expression.lt 对应SQL中的 “field < value” 表达式
- Expression.le 对应SQL中的 “field <= value” 表达式
- Expression.between 对应SQL中的 “between” 表达式
如下面的表达式表示年龄(age)位于13到50区间内。
- Expression.between("age",new Integer(13),new Integer(50));
表达式
- Expression.in 对应SQL中的 ”field in …” 表达式
- Expression.eqProperty 用于比较两个属性之间的值,对应SQL中的“field = field”。 如:
- Expression.eqProperty( "TUser.groupID", "TGroup.id" );
- Expression.gtProperty 用于比较两个属性之间的值,对应SQL中的“field > field”。
- Expression.geProperty 用于比较两个属性之间的值,对应SQL中的“field >= field”。
- Expression.ltProperty 用于比较两个属性之间的值,对应SQL中的“field < field”。
- Expression.leProperty 用于比较两个属性之间的值,对应SQL中的“field <= field”。
- Expression.and and关系组合。 如:
- Expression.and( Expression.eq("name","Erica"), Expression.eq( "sex", new Integer(1) ) );
- Expression.or or关系组合。 如:
- Expression.or( Expression.eq("name","Erica"), Expression.eq("name","Emma") );
Expression.sql 作为补充,本方法提供了原生SQL语法的支持。我们可以通过这个方法直接通过SQL语句限定查询条件。 下面的代码返回所有名称以“Erica”起始的记录:
- Expression.sql( “lower({alias}.name) like lower(?)”, "Erica%", Hibernate.STRING );
其中的“{alias}”将由Hibernate在运行期使用当前关联的POJO别名替换。 注意Expression 各方法中的属性名参数(如Express.eq中的第一个参数),这里 所谓属性名是POJO中对应实际库表字段的属性名(大小写敏感),而非库表中的实际字段名称。
Criteria 高级特性
限定返回的记录范围
通过criteria. setFirstResult/setMaxResults 方法可以限制一次查询返回的记录范围:
- Criteria criteria = session.createCriteria(TUser.class);
- //限定查询返回检索结果中,从第一百条结果开始的20条记录
- criteria.setFirstResult(100);
- criteria.setMaxResults(20);
- 对查询结果进行排序
- //查询所有groupId=2的记录
- //并分别按照姓名(顺序)和groupId(逆序)排序
- Criteria criteria = session.createCriteria(TUser.class);
- criteria.add(Expression.eq("groupId",new Integer(2)));
- criteria.addOrder(Order.asc("name"));
- criteria.addOrder(Order.desc("groupId"));
- criteria用法
- criteria 用法
- Criteria用法
- Hibernate中的Criteria用法
- Hibernate中Criteria用法
- Hibernate中Criteria用法
- Criteria DetachedCriteria 用法
- Hibernate Criteria 用法
- Hibernate Criteria 基本用法
- hibernate criteria完整用法
- Criteria的完整用法
- criteria完整用法
- Criteria的完整用法
- Yii Criteria 查询用法
- Hibernate中的Criteria用法
- Criteria用法的小结
- Criteria的用法
- Criteria查询用法
- 架构师是这样炼成的——专访资深架构师林伟炎
- 理解套接字recv(),send()
- 今日开博
- 1.30杂记
- 占豪--中欧第一轮政治试探完毕
- criteria用法
- ASP.NET控件开发基础之类型转换器浅析
- 如何在SQL Server 2005中建立主外键关系?如何实现级联删除效果?
- 对Sql Server中的表添加级联更新和级联删除的几种方法
- 系统架构师是怎样炼成的?
- JavaScript Math类的三个ceil()、floor()、round()的区别
- 如何在C#中使用存储过程(SQL Server 2000)
- 常见主板检测卡出现的错误代码及解决办法
- 任意对象数组ArrayList的排序法(可自定义排序字段、排序方向)