`
wtnhwbb
  • 浏览: 166677 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Criteria Query 转

阅读更多

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 实例实际上是SQL Select * from t_user where

 name=Ericaand sex=<chmetcnv tcsc="0" w:st="on" unitname="”" sourcevalue="1" numbertype="1" negative="False" hasspace="False"></chmetcnv>1的封装(我们可以打开Hibernate show_sql 选项,

 以观察Hibernate在运行期生成的SQL语句)。

 Hibernate 在运行期会根据Criteria 中指定的查询条件(也就是上面代码中通过

 criteria.add方法添加的查询表达式)生成相应的SQL语句。

 这种方式的特点是比较符合Java 程序员的编码习惯,并且具备清晰的可读性。正因

 为此,不少ORM实现中都提供了类似的实现机制(如Apache OJB)。

 对于Hibernate的初学者,特别是对SQL了解有限的程序员而言,Criteria Query

 无疑是上手的极佳途径,相对HQLCriteria Query提供了更易于理解的查询手段,借

 IDECoding Assist机制,Criteria的使用几乎不用太多的学习。

 Criteria 查询表达式

 Criteria 本身只是一个查询容器,具体的查询条件需要通过Criteria.add

 方法添加到Criteria实例中。

 如前例所示,Expression 对象具体描述了查询条件。针对SQL 语法,

 Expression提供了对应的查询限定机制,包括:

 方法 描述

 Expression.eq 对应SQLfield = 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)位于1350间内。

 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作为一种对象化的查询封装模式,不过由于Hibernate在实现过程中将精力

 更加集中在HQL查询语言上,因此Criteria的功能实现还没做到尽善尽美(这点上,OJB

 Criteria 实现倒是值得借鉴),因此,在实际开发中,建议还是采用Hibernate

 方推荐的查询封装模式:HQL

分享到:
评论

相关推荐

    Hibernate中Criteria的完整用法.docx

    Hibernate 中 Criteria 的完整用法 Hibernate 中 Criteria 的完整用法是 Hibernate 框架中的一种查询机制,允许开发者灵活地根据查询条件来组装查询语句。在使用 Spring 和 Hibernate 进行开发时,Criteria 的优势...

    Criteria标准化对象查询小例子

    1. **创建CriteriaQuery对象**: 首先,我们需要实例化CriteriaQuery,并指定返回的实体类型。 2. **设置Root**: 指定查询的实体,并关联到对应的数据库表。 3. **构建Predicate**: 使用CriteriaBuilder创建各种...

    Hibernate_Query查询所有数据

    CriteriaQuery&lt;YourEntityName&gt; criteriaQuery = builder.createQuery(YourEntityName.class); Root&lt;YourEntityName&gt; root = criteriaQuery.from(YourEntityName.class); TypedQuery&lt;YourEntityName&gt; typedQuery ...

    Hibernat 使用Criteria查询多对多关系(SET集合)条件

    ### Hibernat 使用Criteria查询多对多关系(SET集合)条件 #### 背景介绍与概念理解 在Java开发中,特别是在企业级应用中,持久化层的处理至关重要。Hibernate作为一款流行的Java持久化框架,它提供了一种非常简便...

    Hibernate中Criteria的完整用法

    Hibernate中的Criteria API是一种用于执行动态查询的机制,它允许开发者在运行时...在实际项目中,可以根据需求选择使用HQL(Hibernate Query Language)或Criteria API,两者各有优势,选择取决于具体场景和团队偏好。

    criteria介绍与使用

    与HQL(Hibernate Query Language)相比,`Criteria`API更接近于面向对象的风格,使得查询构建更为简单明了。 #### 使用示例 下面通过几个具体的例子来展示如何使用`Criteria`API。 ##### 示例1:创建基本查询 `...

    Hibernate中Criteria的用法

    Criteria 查询机制主要包括 QBE(Query By Example)、QBC(Query By Criteria)和 HQL(Hibernate Query Language)三种方式。 QBE(Query By Example) QBE 是一种基于示例的查询机制,它可以根据一个示例对象来...

    Criteria的完整用法.pdf

    Query条件组装 - **FetchMode**:控制Hibernate如何加载关联对象,如EAGER(急切加载)和LAZY(延迟加载),影响查询性能和资源消耗。 - **Sort Order**:设置查询结果的排序方式,通过`Criteria`的`addOrder...

    关联映射hibernate的criteria的用法

    通过阅读`Hibernate--Criteria`中的源码,你可以深入了解Criteria API的工作原理,以及如何与其他Hibernate组件(如SessionFactory、Session和Query)协同工作。理解源码能帮助你在实际项目中更好地应用和优化...

    Hibernate的Criteria用法总结

    在Java持久层框架...然而,对于非常复杂的查询,HQL(Hibernate Query Language)可能会更适合,因为它更接近SQL,能更好地表达复杂的查询逻辑。理解并熟练运用Criteria API,能有效提升在Hibernate中的查询效率。

    Hibernate的Criteria文档

    在Java的持久层框架Hibernate中,Criteria API是一个强大的查询工具,它可以用来替代传统的SQL或HQL(Hibernate Query Language)查询,以实现更加面向对象的数据库交互。Criteria API的设计旨在屏蔽不同数据库之间...

    Hibernate-Criteria_模糊查询

    当然,随着项目的复杂度增加,可能还需要结合其他高级查询技术,如HQL(Hibernate Query Language)或JPQL(Java Persistence Query Language),以满足更复杂的查询需求。但无论如何,掌握Hibernate-Criteria的模糊...

    Criteria用法

    在Java的Hibernate框架中,Criteria API提供了一种用于动态构建查询的方法,它是Query By Criteria(QBC)查询方式的一部分。这种方式允许开发者避开编写HQL(Hibernate Query Language)语句,而是通过API调用来...

    Hibernate Criteria 排序的問題

    对于简单的查询场景,使用HQL(Hibernate Query Language)即可轻松实现排序功能;但对于复杂的多表关联查询场景,则需要借助Criteria API来灵活构建查询条件。本文将围绕给定的代码片段,深入探讨Hibernate ...

    hibernate criteria的使用方法

    ### Hibernate Criteria 使用方法详解 #### 一、简介 Hibernate 是一款非常流行的 Java 持久层框架,它简化了对象关系映射(ORM)过程中的许多复杂性。在 Hibernate 中,Criteria API 提供了一种类型安全的方式来...

    \Hibernate_query条件查询

    4. **Query and Criteria的参数化** 两者都支持参数化查询,防止SQL注入。例如,根据用户名查找用户: ```java // HQL Query query = session.createQuery("from User where username = :username"); query....

    hibernate criteria 分组 排序 关联

    ### 六、基于对象的查询(Query Based on Objects) 当查询条件基于一个实体对象时,可以使用`Example.create()`方法。 **示例代码**: ```java User user = new User(); user.setAge(30); Criteria criteria = ...

Global site tag (gtag.js) - Google Analytics