Hibernate Criteria查询详解:离线查询DetachedCriteria

需积分: 0 2 下载量 114 浏览量 更新于2024-08-18 收藏 116KB PPT 举报
"这篇资料主要总结了Hibernate框架中的离线查询——Criteria的使用,包括DetachedCriteria、Criteria的基本操作、投影以及别名等概念。" 在Hibernate中,Criteria API提供了一种面向对象的方式来构建SQL查询,它使得在Java代码中进行数据库查询变得更加直观和灵活。Criteria API属于`org.hibernate.Criteria`接口,它表示一个特定持久类的查询。下面将对Criteria的主要方面进行详细说明: 1. 创建Criteria 创建Criteria对象是通过Hibernate的`Session`接口完成的,例如: ```java Criteria criteria = session.createCriteria(User.class); ``` 这里`User.class`代表要查询的实体类。 2. Criteria简介 - 行操作:Criteria提供了`Example`、`Property`和`Restrictions`等方法来处理行级别的查询条件。 - 列操作:`Projections`用于设置查询结果的列,比如获取平均值、计数或特定列的值。 3. 离线查询 - DetachedCriteria `DetachedCriteria`允许我们在不直接与数据库交互的情况下构建查询,这在多线程或者缓存查询场景中非常有用。你可以先创建一个DetachedCriteria对象,然后在需要的时候再将其与Session关联执行。 4. Criteria的其他操作 - 别名操作:`createAlias()`用于指定关联关系的别名,方便后续操作,例如: ```java criteria.createAlias("address", "addr"); ``` 这里`address`是实体类的一个属性,`addr`是为其指定的别名。 - 投影(Projections):`Projections`类提供了多种方法来设置查询的返回值,如`Projections.count("id")`计算id的数量。 - 级联操作:`createCriteria()`可以用来添加子查询,创建新的Criteria来处理复杂的关联查询。 5. 过时和常用方法 Criteria API中有过时和非过时的方法,对于开发来说,应该主要使用非过时的方法。例如,`add(Criterion criterion)`用于添加查询条件,`addOrder(Order order)`则用于指定查询结果的排序方式。 6. 参数化方法 方法如`createCriteria(String propertyName)`和`createCriteria(String propertyName, String alias)`分别用于创建子Criteria,其中`propertyName`是关联属性的名称,`alias`是可选的别名。 7. 实际应用 在实际编程中,通常会结合Restrictions类提供的各种条件(如`eq()`, `gt()`, `lt()`等)来构建复杂的查询条件,然后使用Projections来定义查询结果的格式,最后通过`list()`或`uniqueResult()`方法执行查询。 通过这些基本操作,开发者可以构建出灵活且易于维护的查询逻辑,避免了硬编码SQL语句,提高了代码的可读性和可维护性。在大型项目中,尤其是在需要大量动态查询的情况下,Criteria API是一个非常实用的选择。