Hibernate Criteria查询教程:条件组合查询和排序
需积分: 3 106 浏览量
更新于2024-07-13
收藏 323KB PPT 举报
"条件或方式组合查询条件-T21.9_Criteria查询java经典教程经典教材"
本篇教程主要讲解了如何使用Criteria API在Java中进行组合查询,结合Hibernate框架,通过实例代码演示如何使用Criteria对象进行条件查询,并对查询结果进行排序。
一、Criteria查询简介
Criteria查询是Hibernate框架中的一种查询方式,通过使用Criteria对象可以进行复杂的查询操作。Criteria查询可以与HQL(Hibernate Query Language)查询相比,Criteria查询更灵活、更强大。
二、创建Criteria对象
要使用Criteria查询,首先需要创建一个Criteria对象,使用SessionFactory的getCurrentSession()方法获取当前Session对象,然后使用Session的createCriteria()方法创建Criteria对象。例如:
```java
Session session = HibernateSessionFactory.getSessionFactory().getCurrentSession();
Criteria criteria = session.createCriteria(Person.class);
```
三、添加查询条件
使用Criteria对象可以添加多个查询条件,使用Restrictions类中的方法可以创建各种查询条件,例如:
```java
Criterion criterion = Restrictions.or(Restrictions.like("name", "wu%"), Restrictions.eq("deptno", 1100));
criteria.add(criterion);
```
上述代码使用了or()方法将两个查询条件组合起来,第一个条件是name字段以"wu"开头,第二个条件是deptno字段等于1100。
四、排序查询结果
使用Criteria对象可以对查询结果进行排序,使用Order类中的方法可以创建排序对象,例如:
```java
criteria.addOrder(Order.desc("id"));
```
上述代码使用了desc()方法将查询结果按照id字段降序排序。
五、执行查询
使用Criteria对象可以执行查询,使用list()方法可以获取查询结果,例如:
```java
List<Person> lstPerson = criteria.list();
```
六、事务提交
使用Hibernate框架需要提交事务,以确保数据的完整性,例如:
```java
session.beginTransaction().commit();
```
七、Criteria查询的核心方法
Criteria查询的核心方法包括:
* add():添加查询条件
* addOrder():添加排序对象
* list():执行查询
* setMaxResults():设置查询结果的最大数量
* setFirstResult():设置查询结果的起始索引
八、Criteria查询的优点
Criteria查询的优点包括:
* 灵活性强:Criteria查询可以进行复杂的查询操作
* 高效性:Criteria查询可以使用索引和缓存,提高查询效率
* 灵活的排序:Criteria查询可以对查询结果进行灵活的排序
九、总结
本篇教程主要讲解了如何使用Criteria API在Java中进行组合查询,通过实例代码演示了如何使用Criteria对象进行条件查询,并对查询结果进行排序。 Criteria查询是一种强大的查询方式,能够满足复杂的查询需求。
132 浏览量
715 浏览量
118 浏览量
2021-08-12 上传
2021-10-02 上传
2021-08-11 上传
2022-09-20 上传
153 浏览量
185 浏览量
![](https://profile-avatar.csdnimg.cn/7c3401d167b14487879e758e5cb1b284_weixin_42204453.jpg!1)
三里屯一级杠精
- 粉丝: 39
最新资源
- MATLAB实现BA无尺度模型仿真与调试
- PIL-1.1.7图像处理库32位与64位双版本发布
- Jacob项目1.18版本更新,发布M2版本压缩包
- RemapKey:永久重映射键盘按键,便捷后台设置
- Coursera上的Python数据科学入门指南
- C++实现常见排序算法,涵盖多种排序技巧
- 深入学习Webpack5:前端资源构建与模块打包
- SourceInsight颜色字体配置指南
- ECShop图片延时加载插件实现免费下载
- AWS无服务器计算演示与地理图案项目
- Minerva Chrome扩展程序的重新设计与优化
- Matlab例程:石墨烯电导率与介电常数的计算
- 专业演出音乐排序播放器,体育活动音效管理
- FMT star算法:利用Halton序列实现路径规划
- Delphi二维码生成与扫码Zxing源码解析
- GitHub Pages入门:如何维护和预览Markdown网站内容