Hibernate Criteria查询详解:离线查询DetachedCriteria
需积分: 0 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是一个非常实用的选择。
2019-08-12 上传
2018-04-17 上传
2011-08-30 上传
2023-04-29 上传
2023-06-02 上传
2023-06-02 上传
2023-09-11 上传
2023-05-18 上传
2023-05-17 上传
郑云山
- 粉丝: 18
- 资源: 2万+
最新资源
- 解决Eclipse配置与导入Java工程常见问题
- 真空发生器:工作原理与抽吸性能分析
- 爱立信RBS6201开站流程详解
- 电脑开机声音解析:故障诊断指南
- JAVA实现贪吃蛇游戏
- 模糊神经网络实现与自学习能力探索
- PID型模糊神经网络控制器设计与学习算法
- 模糊神经网络在自适应PID控制器中的应用
- C++实现的学生成绩管理系统设计
- 802.1D STP 实现与优化:二层交换机中的生成树协议
- 解决Windows无法完成SD卡格式化的九种方法
- 软件测试方法:Beta与Alpha测试详解
- 软件测试周期详解:从需求分析到维护测试
- CMMI模型详解:软件企业能力提升的关键
- 移动Web开发框架选择:jQueryMobile、jQTouch、SenchaTouch对比
- Java程序设计试题与复习指南