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)

最后

分享一套我整理的面试干货,这份文档结合了我多年的面试官经验,站在面试官的角度来告诉你,面试官提的那些问题他最想听到你给他的回答是什么,分享出来帮助那些对前途感到迷茫的朋友。

面试经验技巧篇
  • 经验技巧1 如何巧妙地回答面试官的问题
  • 经验技巧2 如何回答技术性的问题
  • 经验技巧3 如何回答非技术性问题
  • 经验技巧4 如何回答快速估算类问题
  • 经验技巧5 如何回答算法设计问题
  • 经验技巧6 如何回答系统设计题
  • 经验技巧7 如何解决求职中的时间冲突问题
  • 经验技巧8 如果面试问题曾经遇见过,是否要告知面试官
  • 经验技巧9 在被企业拒绝后是否可以再申请
  • 经验技巧10 如何应对自己不会回答的问题
  • 经验技巧11 如何应对面试官的“激将法”语言
  • 经验技巧12 如何处理与面试官持不同观点这个问题
  • 经验技巧13 什么是职场暗语

面试真题篇
  • 真题详解1 某知名互联网下载服务提供商软件工程师笔试题
  • 真题详解2 某知名社交平台软件工程师笔试题
  • 真题详解3 某知名安全软件服务提供商软件工程师笔试题
  • 真题详解4 某知名互联网金融企业软件工程师笔试题
  • 真题详解5 某知名搜索引擎提供商软件工程师笔试题
  • 真题详解6 某初创公司软件工程师笔试题
  • 真题详解7 某知名游戏软件开发公司软件工程师笔试题
  • 真题详解8 某知名电子商务公司软件工程师笔试题
  • 真题详解9 某顶级生活消费类网站软件工程师笔试题
  • 真题详解10 某知名门户网站软件工程师笔试题
  • 真题详解11 某知名互联网金融企业软件工程师笔试题
  • 真题详解12 国内某知名网络设备提供商软件工程师笔试题
  • 真题详解13 国内某顶级手机制造商软件工程师笔试题
  • 真题详解14 某顶级大数据综合服务提供商软件工程师笔试题
  • 真题详解15 某著名社交类上市公司软件工程师笔试题
  • 真题详解16 某知名互联网公司软件工程师笔试题
  • 真题详解17 某知名网络安全公司校园招聘技术类笔试题
  • 真题详解18 某知名互联网游戏公司校园招聘运维开发岗笔试题

资料整理不易,点个关注再走吧
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
笔试题

  • 真题详解5 某知名搜索引擎提供商软件工程师笔试题
  • 真题详解6 某初创公司软件工程师笔试题
  • 真题详解7 某知名游戏软件开发公司软件工程师笔试题
  • 真题详解8 某知名电子商务公司软件工程师笔试题
  • 真题详解9 某顶级生活消费类网站软件工程师笔试题
  • 真题详解10 某知名门户网站软件工程师笔试题
  • 真题详解11 某知名互联网金融企业软件工程师笔试题
  • 真题详解12 国内某知名网络设备提供商软件工程师笔试题
  • 真题详解13 国内某顶级手机制造商软件工程师笔试题
  • 真题详解14 某顶级大数据综合服务提供商软件工程师笔试题
  • 真题详解15 某著名社交类上市公司软件工程师笔试题
  • 真题详解16 某知名互联网公司软件工程师笔试题
  • 真题详解17 某知名网络安全公司校园招聘技术类笔试题
  • 真题详解18 某知名互联网游戏公司校园招聘运维开发岗笔试题

[外链图片转存中…(img-uXLxC6EO-1713854870784)]

资料整理不易,点个关注再走吧
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值