Java Hibernate Criteria查询教程:基础与示例
5星 · 超过95%的资源 需积分: 9 195 浏览量
更新于2024-07-29
收藏 323KB PPT 举报
"T21.9_Criteria查询 java 经典教程 经典教材"
这篇教程聚焦于Java中的Criteria查询,这是一个在Hibernate框架中用于构建动态SQL查询的强大工具。Criteria查询提供了一种面向对象的方式来执行数据库查询,允许开发者在运行时根据业务需求构造查询条件,而无需直接编写SQL语句。
Criteria查询主要由以下部分构成:
1. Criteria对象的创建:首先,你需要通过SessionFactory获取到Session对象,然后调用Session的createCriteria()方法来创建Criteria对象。例如:
```java
Session session = HibernateSessionFactory.getSessionFactory().getCurrentSession();
Criteria criteria = session.createCriteria(Person.class);
```
这将创建一个用于Person类的Criteria查询对象。
2. 添加查询条件:Criteria对象提供了多种方法来添加查询条件,如add()、createCriteria()、createAlias()等。你可以使用这些方法来指定查询的WHERE子句。例如,添加一个年龄大于30岁的条件:
```java
criteria.add(Restrictions.gt("age", 30));
```
3. 排序(Order):Criteria查询还支持对结果进行排序。你可以使用createCriteria()方法的addOrder()或addOrders()来指定ORDER BY子句。例如,按姓名升序排列:
```java
criteria.addOrder(Order.asc("name"));
```
4. 分组(Group By)与聚合函数(Aggregation):虽然Criteria查询通常用于简单的查询,但也可以通过创建 Projection 和 Criterion 对象来实现分组和聚合功能。例如,计算平均年龄:
```java
ProjectionList projections = Projections.projectionList();
projections.add(Projections.avg("age"));
criteria.setProjection(projections);
```
5. 执行查询:最后,使用Criteria对象的list()方法执行查询并获取结果列表:
```java
List<Person> lstPerson = criteria.list();
```
6. 按示例查询(QueryByExample, QBE):Criteria查询还包括按示例查询,这是一种更直观的方式,根据一个对象实例的属性来构建查询条件。例如:
```java
Person examplePerson = new Person();
examplePerson.setName("John");
Example example = Example.create(examplePerson);
criteria.add(example);
```
7. 事务处理:在执行Criteria查询时,通常需要包裹在事务中,以确保数据操作的一致性:
```java
session.beginTransaction();
// 执行查询...
session.getTransaction().commit();
```
Criteria查询的优点在于它的灵活性和可读性,使得在Java应用中处理复杂的查询需求变得更加容易和直观。它与Hibernate的其他特性如HQL(Hibernate Query Language)一起,提供了全面的数据访问解决方案。通过深入学习和熟练掌握Criteria查询,开发者可以更好地利用Hibernate来构建高效且易于维护的Java应用。
2022-09-22 上传
2023-05-28 上传
2023-06-28 上传
2023-04-02 上传
2023-05-24 上传
2023-06-11 上传
2024-03-16 上传
2023-06-28 上传
天意
- 粉丝: 47
- 资源: 155
最新资源
- 构建Cadence PSpice仿真模型库教程
- VMware 10.0安装指南:步骤详解与网络、文件共享解决方案
- 中国互联网20周年必读:影响行业的100本经典书籍
- SQL Server 2000 Analysis Services的经典MDX查询示例
- VC6.0 MFC操作Excel教程:亲测Win7下的应用与保存技巧
- 使用Python NetworkX处理网络图
- 科技驱动:计算机控制技术的革新与应用
- MF-1型机器人硬件与robobasic编程详解
- ADC性能指标解析:超越位数、SNR和谐波
- 通用示波器改造为逻辑分析仪:0-1字符显示与电路设计
- C++实现TCP控制台客户端
- SOA架构下ESB在卷烟厂的信息整合与决策支持
- 三维人脸识别:技术进展与应用解析
- 单张人脸图像的眼镜边框自动去除方法
- C语言绘制图形:余弦曲线与正弦函数示例
- Matlab 文件操作入门:fopen、fclose、fprintf、fscanf 等函数使用详解