东莞市建设培训中心网站,扶风高端企业网站建设,如何在外管局网站做延期,适合夜晚直播软件Criteria Query通过面向对象化的设计#xff0c;将数据查询条件封装为一个对象。简单来讲#xff0c;Criteria Query可以看作是传统SQL的对象化表示#xff0c;如#xff1a;Java代码Criteria criteria session.createCriteria(User.class);criteria.add(Expression.eq(将数据查询条件封装为一个对象。简单来讲Criteria Query可以看作是传统SQL的对象化表示如Java代码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提供了对应的查询限定机制包括Java代码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区间内。Java代码Expression.between(age,new Integer(13),new Integer(50));表达式Java代码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”起始的记录Java代码Expression.sql( “lower({alias}.name) like lower(?)”, Erica%, Hibernate.STRING );Expression.sql( “lower({alias}.name) like lower(?)”, Erica%, Hibernate.STRING );其中的“{alias}”将由Hibernate在运行期使用当前关联的POJO别名替换。 注意Expression 各方法中的属性名参数(如Express.eq中的第一个参数)这里 所谓属性名是POJO中对应实际库表字段的属性名(大小写敏感)而非库表中的实际字段名称。Criteria 高级特性限定返回的记录范围通过criteria. setFirstResult/setMaxResults 方法可以限制一次查询返回的记录范围:Java代码Criteria criteria session.createCriteria(TUser.class);//限定查询返回检索结果中从第一百条结果开始的20条记录criteria.setFirstResult(100);criteria.setMaxResults(20);对查询结果进行排序//查询所有groupId2的记录//并分别按照姓名(顺序)和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 session.createCriteria(TUser.class);//限定查询返回检索结果中从第一百条结果开始的20条记录criteria.setFirstResult(100);criteria.setMaxResults(20);对查询结果进行排序//查询所有groupId2的记录//并分别按照姓名(顺序)和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));分享到 2009-06-01 09:20浏览 7961评论2 楼senhui192010-11-12嗯写的不错收藏起来方便以后查看呵呵~~1 楼hanz1882010-07-30楼主总结的真好我看完之后基本上就了解了criteria的概念和用法了。如果页面能够重新排下版就更好了另外最后一段代码重复了能不能删除一个。