【Hibernate】hql使用总结(上)

2024-08-26 19:38
文章标签 总结 使用 hibernate hql

本文主要是介绍【Hibernate】hql使用总结(上),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

    hibernate是一个全自动的 ORM映射,拥有特色的hql语句,它可以自动生成sql语句自动执行。和sql语句有很多相似的地方,之前做项目的时候用过,但是理解的不够全面,体会最深刻的就是把表名写作实体类名,现在看来那只是冰山一角,下面来更加全面的总结一下。

一、.简单属性查询

1.单一属性查询

//返回结果集属性列表,元素类型和实体类中的属性类型一致List students = session.createQuery("select name from Student").list();
取值:

for (Iterator iter=students.iterator(); iter.hasNext();) {String name = (String)iter.next();System.out.println(name);}

2.多个属性查询

//查询多个属性,返回对象数组集合//数组元素的类型与查询的属性类型一致//数组的长度与select中查询的属性个数一致List students = session.createQuery("select id, name from Student").list();
取值:

for (Iterator iter=students.iterator(); iter.hasNext();) {Object[] obj = (Object[])iter.next();System.out.println(obj[0] + ", " + obj[1]);}

3.多个属性查询,返回对象

//可以使用hql返回Student对象
//需要提供构造函数
List students = session.createQuery("select new Student(id, name) from Student").list();
取值:

for (Iterator iter=students.iterator(); iter.hasNext();) {Student student = (Student)iter.next();System.out.println(student.getId() + ", " + student.getName());}

4.使用别名查询

List students = session.createQuery("select s.id, s.name from Student s").list();
取值和多属性查询是一样的,不在多述。

二、实体对象查询

使用实体对象查询时会返回实体对象的集合,可以采用两种方法,一个方法采用list方法,另一种是iterate方法。查询时可以忽略select关键字,可以使用别名,注意如果使用select查询实体对象,必须使用别名,不支持使用select * from这种语法,使用这种语法时不能用实体名要用表名。

1.list方法

			/*** 采用list查询实体对象会发出一条查询语句,取得实体对象数据* * Hibernate: select student0_.id as id0_, student0_.name as name0_, * student0_.createTime as createTime0_, student0_.classesid as classesid0_ * from t_student student0_*/List students = session.createQuery("from Student").list();


取值:

for (Iterator iter=students.iterator(); iter.hasNext();) {Student student = (Student)iter.next();System.out.println(student.getName());}

2.iterate方法

/*** 会出现N+1问题,所谓的N+1指的是发出了N+1条sql语句* * 1:发出一条查询id列表的语句* Hibernate: select student0_.id as col_0_0_ from t_student student0_* * N:根据id发出N条sql语句,加载相关的对象* Hibernate: select student0_.id as id0_0_, student0_.name as name0_0_, * student0_.createTime as createTime0_0_, student0_.classesid as classesid0_0_ * from t_student student0_ where student0_.id=?* */
Iterator iter = session.createQuery("from Student").iterate();
取值:
while (iter.hasNext()) {Student student = (Student)iter.next();System.out.println(student.getName());}

    使用list时hibernate会发出一条sql语句,查询实体对应表的所有数据,使用iteratehibernate会首先发出一条查询所有id的sql语句,然后用每个id为条件查询耽搁数据,这时会发出n+1条sql语句。为了避免这种问题,可以先执行list操作,将数据放到session一级缓存中,再采用iterate的时候首先会发出一条查询id列表的语句,再根据id到缓存中加载相应的数据,如果缓存中存在与之匹配的数据则不再发出根据id查询的sql语句,直接使用缓存中的数据,这样可以提高性能。

List students = session.createQuery("from Student").list();for (Iterator iter=students.iterator(); iter.hasNext();) {Student student = (Student)iter.next();System.out.println(student.getName());}System.out.println("-----------------------------------------------------");Iterator iter = session.createQuery("from Student").iterate();while (iter.hasNext()) {Student student = (Student)iter.next();System.out.println(student.getName());}

三.条件查询

1.简单条件查询

List students = session.createQuery("select s.id, s.name from Student s where s.name like '%0%'").list();

2.使用?方式传递参数查询

注意索引是从0开始,不同于jdbc从1开始

List students = session.createQuery("select s.id, s.name from Student s where s.name like ?").setParameter(0, "%0%").list();

//采用 ?方式,查询学号为1,2,3,4,5的学生List students = session.createQuery("select s.id, s.name from Student s where s.id in(?, ?, ?, ?, ?)").setParameter(0, 1).setParameter(1, 2).setParameter(2, 3).setParameter(3, 4).setParameter(4, 5).list();for (Iterator iter=students.iterator(); iter.hasNext();) {Object[] obj = (Object[])iter.next();System.out.println(obj[0] + ", " + obj[1]);}

3.采用:参数名的方式传递参数

List students = session.createQuery("select s.id, s.name from Student s where s.name like :myname").setParameter("myname",  "%0%").list();

4.调用mysql日期格式化函数

//查询2017-01的学生,可以调用mysql的日期格式化函数List students = session.createQuery("select s.id, s.name from Student s where date_format(s.createTime, '%Y-%m')=?").setParameter(0,  "2017-01").list();
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");//查询2017-01-14 到2017-01-15的学生,可以调用mysql的日期格式化函数List students = session.createQuery("select s.id, s.name from Student s where s.createTime between ? and ?").setParameter(0, sdf.parse("2017-01-14 00:00:00")).setParameter(1, sdf.parse("2017-01-15 13:59:59")).list();

四、对原生sql的支持

List students = session.createSQLQuery("select * from t_student").list();

小结:


    先简单总结一部分hql语句,hql语句查询时使用使用类名,关键字习惯上我们用小写,通过实体类和表的映射找到数据库表。下篇博客总结hql语句的其他,外置命名查询,传过滤器,分页查询等等。现在感觉hibernate的hql还是挺强大的,O/R映射能力强,如果封装了hibernate,项目的持久层代码会特别简单,写的代码也比较少,开发速度会很快的。



这篇关于【Hibernate】hql使用总结(上)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1109496

相关文章

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所

C++11右值引用与Lambda表达式的使用

《C++11右值引用与Lambda表达式的使用》C++11引入右值引用,实现移动语义提升性能,支持资源转移与完美转发;同时引入Lambda表达式,简化匿名函数定义,通过捕获列表和参数列表灵活处理变量... 目录C++11新特性右值引用和移动语义左值 / 右值常见的左值和右值移动语义移动构造函数移动复制运算符

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

C#中lock关键字的使用小结

《C#中lock关键字的使用小结》在C#中,lock关键字用于确保当一个线程位于给定实例的代码块中时,其他线程无法访问同一实例的该代码块,下面就来介绍一下lock关键字的使用... 目录使用方式工作原理注意事项示例代码为什么不能lock值类型在C#中,lock关键字用于确保当一个线程位于给定实例的代码块中时

MySQL 强制使用特定索引的操作

《MySQL强制使用特定索引的操作》MySQL可通过FORCEINDEX、USEINDEX等语法强制查询使用特定索引,但优化器可能不采纳,需结合EXPLAIN分析执行计划,避免性能下降,注意版本差异... 目录1. 使用FORCE INDEX语法2. 使用USE INDEX语法3. 使用IGNORE IND