九、hibernate的查询(QBC)
QBC:Query By Criteria
- 条件查询
- 比较适合组合条件查询
QBC查询
简单查询
创建Criteria对象:Criteria criteria = session.createCriteria(Children.class);
获取查询的对象集合:List<Children> list = criteria.list();
@Test
public void query() {
Session session = HibernateUtils.getCurrentSession();
Transaction tx = session.beginTransaction(); Criteria criteria = session.createCriteria(Children.class);
List<Children> list = criteria.list(); for (Children children : list) {
System.out.println(children);
} tx.commit();
}
排序查询
addOrder()
- 添加排序方法
Order.desc(属性名)、Order.asc(属性名)
- criteria.addOrder(Order.desc("cid"));//降序
- criteria.addOrder(Order.asc("cid"));//升序
@Test
public void query() {
Session session = HibernateUtils.getCurrentSession();
Transaction tx = session.beginTransaction(); Criteria criteria = session.createCriteria(Children.class);
criteria.addOrder(Order.desc("cid"));//降序
//criteria.addOrder(Order.asc("cid"));//升序
List<Children> list = criteria.list(); for (Children children : list) {
System.out.println(children);
} tx.commit();
}
分页查询
从第几条记录开始:criteria.setFirstResult(int);
一页总共多少条记录:criteria.setMaxResults(int);
@Test
public void query() {
Session session = HibernateUtils.getCurrentSession();
Transaction tx = session.beginTransaction(); Criteria criteria = session.createCriteria(Children.class); criteria.setFirstResult(3);
criteria.setMaxResults(5); List<Children> list = criteria.list(); for (Children children : list) {
System.out.println(children);
} tx.commit();
}
条件查询
criteria.add(Restrictions.eq("sex", '0'));
- add():主要用于添加where后面的条件
- Restrictions:条件
- 条件设置方法
- eq():=
- gt():>
- ge:>=
- le:<=
- lt:<
- ne:<>
- like()、in()、and()、or()、...........
@Test
public void query() {
Session session = HibernateUtils.getCurrentSession();
Transaction tx = session.beginTransaction(); Criteria criteria = session.createCriteria(Children.class); criteria.add(Restrictions.eq("sex", '0')); List<Children> list = criteria.list(); for (Children children : list) {
System.out.println(children);
} tx.commit();
}
分组查询
criteria.setProjection(Projection)
- 添加聚合函数以及group by 、having 的条件
@Test
public void query() {
Session session = HibernateUtils.getCurrentSession();
Transaction tx = session.beginTransaction(); Criteria criteria = session.createCriteria(Children.class); criteria.setProjection(Projections.count("sex")); Object obj = criteria.uniqueResult(); System.out.println(obj); tx.commit();
}
离线条件查询
DetachedCriteria类:可以脱离session使用
使用DetachedCriteria的原因
- 多条件查询的时,需要在Web层封装相应的参数到Criteria,而在Dao层才真正的去执行查询数据库的操作
- session是在dao层开始创建使用的,web层一般不出现session,所以需要从web传递参数并且在dao层拼接sql
- DetachedCriteria可以脱离session使用,可以在web层将查询条件设置完毕,然后传递DetachedCriteria对象即可,不需要传递大量参数、拼接sql
DetachedCriteria的使用
- 创建:DetachedCriteria dc = DetachedCriteria.forClass(Children.class);
- 添加查询条件:dc.add(Restrictions.eq("sex", '1'));
- 绑定session并获取Criteria对象:Criteria criteria = dc.getExecutableCriteria(session);
@Test
public void query() {
Session session = HibernateUtils.getCurrentSession();
Transaction tx = session.beginTransaction(); //模拟web层,不需要session的创建
DetachedCriteria dc = DetachedCriteria.forClass(Children.class);
dc.add(Restrictions.eq("sex", '1')); //模拟dao层,绑定session使用
Criteria criteria = dc.getExecutableCriteria(session);
List<Children> list = criteria.list(); for (Children children : list) {
System.out.println(children);
} tx.commit();
}
九、hibernate的查询(QBC)的更多相关文章
- Hibernate高级查询QBC条件设置——Restrictions用法 引自:http://www.cnblogs.com/evon168/archive/2010/10/29/1863059.html
方法说明 方法 说明 Restrictions.eq = Restrictions.allEq 利用Map来进行多个等于的限制 Restrictions.gt > Restrictions.ge ...
- hibernate模糊查询
hibernate模糊查询-Restrictions.ilike & Expression.like Criteria criteria = session.createCriteria(Ta ...
- Hibernate的查询方式总结
Hibernate的查询方式大体有三种,分别是HQL QBC和SQL三种.在网上查阅一一些资料,做了一个简单的总结. 1. SQL sql 是面向数据库表查询,from 后面跟的是表名,where 后 ...
- Hibernate的查询,二级缓存,连接池
Hibernate的查询,二级缓存,连接池 1.Hibernate查询数据 Hibernate中的查询方法有5中: 1.1.Get/Load主键查询 使用get或者load方法来查询,两者之间的区别在 ...
- Hibernate的查询方式
Hibernate的查询的方式 OID检索 get或load方法进行的查询 对象导航检索 linkman.getCustomer(); HQL检索 用于接收hql语句进行查询,面向对象查询方式. 通过 ...
- Hibernate:查询
本文内容 OID查询 对象导航查询 HQL查询 QBC查询 SQL查询 首发日期:2018-07-31 hibernate的查询方式: hibernate有很多查询方式 OID查询 对象导航查询: H ...
- Hibernate高效查询,只查询部分/指定字段
公司使用 DetachedCriteria detachedCriteria = DetachedCriteria.forClass(PeBulletin.class); detachedCriter ...
- Hibernate常用查询语句
Hibernate常用查询语句 Hib的检索方式1'导航对象图检索方式.通过已经加载的对象,调用.iterator()方法可以得到order对象如果是首次执行此方法,Hib会从数据库加载关联的orde ...
- Hibernate的查询的方式
Hibernate的查询的方式 在Hibernate中提供了很多种的查询的方式.Hibernate共提供了五种查询方式. Hibernate的查询方式:OID查询 OID检索:Hibernate根据对 ...
随机推荐
- 20180209-os模块
下面将学习关于os模块的相关操作 项目练习的目录结构如下:所有的操作都是基于os_exercise.py模块 1.获取当前的Python脚本的工作目录路径 os.getcwd() # 1.获取当前目录 ...
- 02.Linux-CentOS系统NFS挂载时拒绝访问挂载问题
问题: 在挂载nfs时报拒绝访问挂载:mount -t nfs 192.163.1.10:/home/opneuser/upload /home/openuser/upload/ 报错信息:Mount ...
- 三、Angular项目,app.module.ts解析
1. 项目主要文件存放的路径 2.app.module.ts模块解析 3.模块和组件关系 |--app.module.ts(模块) |--app.component.ts(组件) |--app.co ...
- CSS书写顺序提高可读性
属性书写顺序 [建议] 同一 rule set 下的属性在书写时,应按功能进行分组,并以 Formatting Model(布局方式.位置) > Box Model(尺寸) > Typog ...
- java资料搜索网站
http://yun.java1234.com/ 盘多多 B站 一个集成了很多springboot功能的地址 https://gitbub.com/runzhenghengbin/SpringBoot ...
- 【leetcode】1023. Binary String With Substrings Representing 1 To N
题目如下: Given a binary string S (a string consisting only of '0' and '1's) and a positive integer N, r ...
- 【leetcode】897. Increasing Order Search Tree
题目如下: 解题思路:我的方法是先用递归的方法找出最左边的节点,接下来再对树做一次递归中序遍历,找到最左边节点后将其设为root,其余节点依次插入即可. 代码如下: # Definition for ...
- 一分钟小知识:scroll-behavior 让你的页面导航滚动更丝滑~
中午在[掘金]潜水摸鱼,看到这一个沸点,个人已经撸出特效: 下面放上 作者 的 掘金 地址 #掘金沸点# https://juejin.im/pin/5d649eaaf265da19752533d ...
- tree 解题报告
tree 对于 \(n\) 个点带标号的无根森林,计算所有森林的树的个数的 \(k\) 次方,对 \(998244353\) 取模. 自闭,错了一堆关于长度的问题,这里以后一定要注意 比如需要 \(n ...
- 测开之路五十七:实现runner和测试报告
准备测试用例 from fox.case import Casefrom src import Calculator class TestCalculator(Case): def setUp(sel ...