【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常用命令提示符使用方法详解

《Python常用命令提示符使用方法详解》在学习python的过程中,我们需要用到命令提示符(CMD)进行环境的配置,:本文主要介绍Python常用命令提示符使用方法的相关资料,文中通过代码介绍的... 目录一、python环境基础命令【Windows】1、检查Python是否安装2、 查看Python的安

Python并行处理实战之如何使用ProcessPoolExecutor加速计算

《Python并行处理实战之如何使用ProcessPoolExecutor加速计算》Python提供了多种并行处理的方式,其中concurrent.futures模块的ProcessPoolExecu... 目录简介完整代码示例代码解释1. 导入必要的模块2. 定义处理函数3. 主函数4. 生成数字列表5.

Python中help()和dir()函数的使用

《Python中help()和dir()函数的使用》我们经常需要查看某个对象(如模块、类、函数等)的属性和方法,Python提供了两个内置函数help()和dir(),它们可以帮助我们快速了解代... 目录1. 引言2. help() 函数2.1 作用2.2 使用方法2.3 示例(1) 查看内置函数的帮助(

Linux脚本(shell)的使用方式

《Linux脚本(shell)的使用方式》:本文主要介绍Linux脚本(shell)的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述语法详解数学运算表达式Shell变量变量分类环境变量Shell内部变量自定义变量:定义、赋值自定义变量:引用、修改、删

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可

LiteFlow轻量级工作流引擎使用示例详解

《LiteFlow轻量级工作流引擎使用示例详解》:本文主要介绍LiteFlow是一个灵活、简洁且轻量的工作流引擎,适合用于中小型项目和微服务架构中的流程编排,本文给大家介绍LiteFlow轻量级工... 目录1. LiteFlow 主要特点2. 工作流定义方式3. LiteFlow 流程示例4. LiteF

使用Python开发一个现代化屏幕取色器

《使用Python开发一个现代化屏幕取色器》在UI设计、网页开发等场景中,颜色拾取是高频需求,:本文主要介绍如何使用Python开发一个现代化屏幕取色器,有需要的小伙伴可以参考一下... 目录一、项目概述二、核心功能解析2.1 实时颜色追踪2.2 智能颜色显示三、效果展示四、实现步骤详解4.1 环境配置4.

使用jenv工具管理多个JDK版本的方法步骤

《使用jenv工具管理多个JDK版本的方法步骤》jenv是一个开源的Java环境管理工具,旨在帮助开发者在同一台机器上轻松管理和切换多个Java版本,:本文主要介绍使用jenv工具管理多个JD... 目录一、jenv到底是干啥的?二、jenv的核心功能(一)管理多个Java版本(二)支持插件扩展(三)环境隔

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用