hibernate的三种查询方式

Query query = session.createQuery(“from Users where uid>5”);

List list = query.list();

for (Users user : list) {

System.out.println(user);

}

1.3、属性查询

查询部分属性

String hql=“select u.uid,u.uname,u.upwd from Users u where u.uname=‘张三’”;

Query query = session.createQuery(hql);

List<Object[]> list = query.list();

for (Object[] objects : list) {

System.out.println(Arrays.toString(objects));

}

String hql=“select new Users(u.uname,u.upwd) from Users u where u.uname=‘张三’”;

Query query = session.createQuery(hql);

List list = query.list();

for (Users user : list) {

System.out.println(user);

}

1.4、实体的更新和删除

从hibernate 3版本开始才支持

//更新

String hql=“update Users set uname=‘王五’,upwd=‘321’ where uid=3”;

int res = session.createQuery(hql).executeUpdate();

//删除

String hql=“delete from Users where uid=3”;

int res = session.createQuery(hql).executeUpdate();

/*

返回值结果:

正整数:表受影响的行数据

0: 语句正常执行,但没有行受影响

负整数:通常是-1,执行HQL语句是一条查询语句

*/

HQL语句不能做添加

1.5、分组与排序

  • 排序

处理方式和SQL语句中的排序是一样的

String hql=“from Users order by uid”;

Query query = session.createQuery(hql);

List list = query.list();

for (Users user : list) {

System.out.println(user);

}

order by语句只能出现在语句的最后位置

  • 分组

处理方式和SQL语句中分组查询相同

分组语句需要处理筛选,只能使用having语句,而不能使用where语句。

String hql = “select e.dept.deptno, count(e) from Emp e group by dept.deptno”;

String hql = “select e.dept.deptno, count(e) from Emp e group by dept.deptno having count(e)>=5”;

1.6、参数绑定

  • 使用占位参数

String hql=“from Users where uid=? or uname=?”;

Query query = session.createQuery(hql);

//索引从0开始

query.setInteger(0, 3);//query.setParameter(0, 3);

query.setString(1, “张三”);//query.setParameter(1, “张三”);

List list = query.list();

for (Users user : list) {

System.out.println(user);

}

  • 使用参数名称

String hql = “from Users where uid=:no1 or uid=:no2”;

Query query = session.createQuery(hql);

query.setInteger(“no1”, 1);

query.setInteger(“no2”, 3);

//…

  • 可以使用点位参数和名称参数混合使用

String hql = “from User where uid=? or uid=:no2”;

Query query = session.createQuery(hql);

query.setInteger(0, 7788);

query.setInteger(“no2”, 7566);

//…

//使用点位参数和名称参数混合使用,所有点位参数必须放在前面,一旦有名称参数出现,其后将不能再出现占位参数

1.7、连接查询

–SQL语句:查询员工姓名、薪资、部门名称

SELECT ENAME,SAL,DNAME

FROM EMP e JOIN DEPT d ON e.DEPTNO=d.DEPTNO

SELECT ENAME,SAL,DNAME FROM EMP,DEPT WHERE EMP.DEPTNO=DEPT.DEPTNO

  1. 没有on语句

  2. 能被连接到查询中的必须是主查询对象的子属性

String hql=“SELECT e.ename, e.sal, e.dept.dname FROM Emp e”;

//HQL连接查询

String hql=“SELECT e.ename, e.sal, d.dname FROM Emp e JOIN e.dept d”;

String hql = “SELECT e FROM Emp e JOIN e.dept”; //JOIN将没有意义

String hql = “FROM Emp e JOIN e.dept”;

Query query = session.createQuery(hql);

List<Object[]> list = query.list();

//List集合中的数组中会保存两个元素:

//0:主数据(Emp)

//1:从数据(Dept)

//查询编号为7788的员工信息,同时将对应的dept信息和manager信息查询并保存在对应的子属性中

String hql = “FROM Emp e JOIN FETCH e.dept d JOIN FETCH e.manager m WHERE e.empno=7788”;

Query query = session.createQuery(hql);

Emp emp = (Emp) query.uniqueResult();

System.out.println(emp);

System.out.println(emp.getManager());

System.out.println(emp.getDept());

1.8、分页

String hql = “from Users”;

Query query = session.createQuery(hql);

query.setFirstResult(0);

query.setMaxResults(2);

2、QBC查询

QBC(Query By Criteria)查询就是通过使用Hibernate提供的Query By Criteria API来查询对象,这种API封装了SQL语句的动态拼装,对查询提供了更加面向对象的功能接口。

QBC查询最重要的三个类:

  1. Restrictions 条件限制

  2. Projections 列设射

  3. Order 排序

2.1、查询实现

Criteria criteria = session.createCriteria(Users.class);

//session.createCriteria(“entity.Users”);

//session.createCriteria(Users.class, “别名”);

List list = criteria.list();

//查询单行结果(如果结果有两行或更多,会报错)

Object uniqueResult = criteria.uniqueResult();

2.2、Projections 列投射

语法:

//查询uname属性

Criteria criteria = session.createCriteria(Users.class);

PropertyProjection property = Projections.property(“name”);

criteria.setProjection(property);

List result = criteria.list();

//查询uname, upwd属性

Criteria criteria = session.createCriteria(Users.class);

//1.创建投射列表

ProjectionList projectionList = Projections.projectionList();

//2.向投射列表中添加列投射

PropertyProjection property1 = Projections.property(“uname”);

PropertyProjection property2 = Projections.property(“upwd”);

projectionList.add(property1).add(property2);

//3.将投射列表设置到准则中

criteria.setProjection(projectionList);

List result = criteria.list();

| 返回值类型 | 方法名称 | 描述 |

| — | — | — |

| PropertyProjection | Projections.property | 指定某属性 |

| AggregateProjection | Projections.avg | 求平均值 |

| CountProjection | Projections.count | 统计某属性的数量 |

| CountProjection | Projections.countDistinct | 统计某属性不同值的数量 |

| PropertyProjection | Projections.groupProperty | 指定某个属性为分组属性 |

| AggregateProjection | Projections.max | 求最大值 |

| AggregateProjection | Projections.min | 求最小值 |

| ProjectionList | Projections.projectionList | 创建一个ProjectionList对象 |

| Projection | Projections.rowCount | 查询结果集中的记录条数 |

| AggregateProjection | Projections.sum | 求某属性的合计 |

2.3、Restrictions 条件限制

语法:https://www.jianshu.com/p/3d3d67663157

Criteria criteria = session.createCriteria(Users.class);

Criterion notNull = Restrictions.isNotNull(“comm”);

criteria.add(notNull); //添加一个条件(如果添加了多个条件,默认条件之间使用and连接)

List list = criteria.list();

| 返回值类型 | 方法名称 | 描述 |

| — | — | — |

| SimpleExpression | Restrictions.eq | 等于(equal) |

| Criterion | Restrictions.allEq | 使用Map,Key/Valu进行多个等于的比对 |

| SimpleExpression | Restrictions.gt | 大于(great than) |

| SimpleExpression | Restrictions.ge | 大于等于(great than or equal) |

| SimpleExpression | Restrictions.lt | 小于(less than) |

| SimpleExpression | Restrictions.le | 小于等于(less than or equal) |

| Criterion | Restrictions.between | 对应SQL的between |

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

总结

我个人认为,如果你想靠着背面试题来获得心仪的offer,用癞蛤蟆想吃天鹅肉形容完全不过分。想必大家能感受到面试越来越难,想找到心仪的工作也是越来越难,高薪工作羡慕不来,却又对自己目前的薪资不太满意,工作几年甚至连一个应届生的薪资都比不上,终究是错付了,错付了自己没有去提升技术。

这些面试题分享给大家的目的,其实是希望大家通过大厂面试题分析自己的技术栈,给自己梳理一个更加明确的学习方向,当你准备好去面试大厂,你心里有底,大概知道面试官会问多广,多深,避免面试的时候一问三不知。

大家可以把Java基础,JVM,并发编程,MySQL,Redis,Spring,Spring cloud等等做一个知识总结以及延伸,再去进行操作,不然光记是学不会的,这里我也提供一些脑图分享给大家:

希望你看完这篇文章后,不要犹豫,抓紧学习,复习知识,准备在明年的金三银四拿到心仪的offer,加油,打工人!
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
作几年甚至连一个应届生的薪资都比不上,终究是错付了,错付了自己没有去提升技术。

这些面试题分享给大家的目的,其实是希望大家通过大厂面试题分析自己的技术栈,给自己梳理一个更加明确的学习方向,当你准备好去面试大厂,你心里有底,大概知道面试官会问多广,多深,避免面试的时候一问三不知。

大家可以把Java基础,JVM,并发编程,MySQL,Redis,Spring,Spring cloud等等做一个知识总结以及延伸,再去进行操作,不然光记是学不会的,这里我也提供一些脑图分享给大家:

[外链图片转存中…(img-LvkBrSxj-1713383020107)]

[外链图片转存中…(img-KMxEwKdA-1713383020108)]

[外链图片转存中…(img-tGiRMLEf-1713383020108)]

希望你看完这篇文章后,不要犹豫,抓紧学习,复习知识,准备在明年的金三银四拿到心仪的offer,加油,打工人!
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

  • 19
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值