SQL语句的DML操作不外乎:增,删,改,查

增加 :  save(),persist()

删除 :   delete()

改动 :   update()

查询  :  get() ,load()

其中的查询操作,作为最为常用的语句,又可以分为很多种情况。通过get()和load()方式,我们仅仅可以指定类型,和id获得一条记录。

当我们需要根据进行条件查询时来获得多条记录时,就不能再使用get(),和load()方式。

Hibernate提供了很强大的查询体系:HQL查询,条件查询,原生SQL查询

1.HQL查询

HQL(Hibernate Query Language)即Hibernate查询语句。Hibernate的语法很像SQL的语法,也可以说事SQL语句的转化。

我们知道SQL语言的操作对象是数据表,列等数据库对象,而HQL语句则是把SQL语句中的数据表替换为持久化类,列替换为属性。

这样HQL就变成了面向对象的查询语言,它可以支持继承,多态等特性。

HQL查询 主要依赖的是Query类,每个Query类的实例对应一个查询对象。Query类的实例对象可以通过session.createQuery(Sting Hql)来获得。最基本的例子如下:

@Test
public void testHQL(){ String hql = "select p.name , p.age from Person p where id = 99"; // HQL语句,name,age,id是Person类实例对象p的属性 Query query = session.createQuery(hql); //获得查询对象
Person p = (Person) query.uniqueResult(); //明确知道查询得到的记录只有一条,用uniqueResult()方法 System.out.println("查询得到的对象是:"+ p);
}

为HQL语句绑定参数:

上面的例子中id=99是静态写死在HQL语句中,但是实际的开发中,常常是根据传进来的参数来查询,静态写死就不灵活了。有两种方法文HQL绑定参数:

第一种:使用 ? 占位符

两点注意:?占位符的索引从1开始,根据属性的类型来选择setXxxx()方法。


@Test
public void testHQL(){ String hql = "select p.name , p.age from Person p where p.id = ? and p.birthday = ?"; // HQL语句,name,age,id,birthday是Person类实例对象p的属性 Query query = session.createQuery(hql); //获得查询对象 query.setInteger(1,99);
query.setDate(2,new Date())
Person p = (Person) query.uniqueResult(); //明确知道查询得到的记录只有一条,用uniqueResult()方法 System.out.println("查询得到的对象是:"+ p);
}

第二种:命名参数进行绑定

格式为   :参数名      设值时根据参数名 进行设值

@Test
public void testHQL(){ String hql = "select p.name , p.age from Person p where p.id = :id and p.birthday = :birthday"; // HQL语句,name,age,id,birthday是Person类实例对象p的属性 Query query = session.createQuery(hql); //获得查询对象 query.setInteger("id",99);
query.setDate("birthday",new Date())
Person p = (Person) query.uniqueResult(); //明确知道查询得到的记录只有一条,用uniqueResult()方法 System.out.println("查询得到的对象是:"+ p);
}

得到查询结果集:

如果 查询的结果是唯一的一条记录,可以调用uniqueResult();    但是当查询的结果是多条记录时,可以使用两个方法来遍历每条记录:

list()方法

@Test
public void testHQL(){ String hql = "select p.name , p.age from Person p where p.birthday > :birthday"; // HQL语句,name,age,id,birthday是Person类实例对象p的属性 Query query = session.createQuery(hql); //获得查询对象 query.setDate("birthday",new Date())
List<Person> list = query.list(); //将查询后的结果转化为list集合
for(Person p : list) //遍历list集合
{
System.out.println("Person实例对象--" + p);
}
}

iterate()方法

@Test
public void testHQL(){ String hql = "select p.name , p.age from Person p where p.birthday > :birthday"; // HQL语句,name,age,id,birthday是Person类实例对象p的属性 Query query = session.createQuery(hql); //获得查询对象 query.setDate("birthday",new Date())
Iterator<Person> iterator = query.iterate(); ////将查询后的结果转化为list集合,然后拿到迭代器对象
while(iterator.hasNext())
{
Person p = iterator.next()
System.out.println("Person-----" + p);
}
}

这两个方法之间的区别是:

list()方式是立即查询  即会立刻发送一条SQL语句将查询的结果集封装在list集合中      ;   list()方法支持一级缓存(session缓存)的写入  不支持读出(就是无论如何都会发SQL语句去查)

iterate()方法是延迟查询  当需要使用某一条查询结果记录时,才发送一条SQL语句,取得这条查询记录   ;  iterate()方法支持一级缓存(session缓存)的写入  支持读出(先看缓存有没有,有就不发SQL,没有再发SQL)

根据上面的HQL语句 可知,SQL语句是按照一条记录一条记录这样的形式来查,HQL语句是按照一个实例对象一个实例对象这样的形式来查。

由于HQL语句中不允许出现*号   所以 select  *  from   tb_person的对应HQL可以写为  select  p.id ,p.name,p.age from Person p ;(列举出所有实例对象p的属性)

也可以简写为  from  Person p;

HQL语句还可以结合 where子句做更为复杂的查询 ,其语法格式类似于SQL语句。

HQL语句也可以做增加,删除,更新的DML操作。   这些操作都涉及到SQL相关知识,这里不再详细叙述。

命名HQL查询:

命名HQL查询 的本质就是把 HQL语句从java代码中取出来,放到配置文件中进行管理,并为这条HQL语句起一个名字,以便在java代码中获取这条HQL语句。

hql.xml配置文件  (名字随意)

<query  name="query1">
select p.id , p.name from Person p;
</query>

还需要在hibernate.cfg.xml配置文件中引入hql.xml配置文件

<mapping resource="org/fkjava/test/hql.xml"/>

java代码:

 @Test
public void testHQL(){ Query query = session.getNamedQuery("query1"); //根据hql名称 ,加载hql语句,得到query对象 List<Person> list = query.list(); //得到查询结果集的list集合
}

Hibernate之HQL的更多相关文章

  1. hibernate的hql查询

    1.概念介绍 1.Query是Hibernate的查询接口,用于从数据存储源查询对象及控制执行查询的过程,Query包装了一个HQL查询语句. 2.HQL是Hibernate Query Langua ...

  2. Hibernate学习-Hibernate查询语言HQL

    HQL(Hibernate Query Language)Hibernate查询语言,语法类似于SQL,可以直接使用实体类及属性. 使用HQL 可以避免使用JDBC 查询的一些弊端 不需要再编写繁复的 ...

  3. Hibernate之HQL查询

    一.Hibernate 提供了以下几种检索对象的方式: 导航对象图检索方式: 根据已经加载的对象导航到其他对象 OID 检索方式: 按照对象的 OID 来检索对象 HQL 检索方式:使用面向对象的 H ...

  4. Hibernate之HQL介绍

    Hibernate中提供了多种检索对象的方式,主要包括以下种类: 导航对象图检索方式:根据已经加载的对象导航到其他对象 OID检索方式:根据对象的OID来检索对象 HQL检索方式:使用面向对象的HQL ...

  5. Hibernate五 HQL查询

    HQL查询一 介绍1.HQL:Hibernate Query Language,是一种完全面向对象的查询语言.使用Hibernate有多重查询方式可供选择:hibernate的HQL查询,也可以使用条 ...

  6. Hibernate 的hql查询简介【申明:来源于网络】

    Hibernate 的hql查询简介[申明:来源于网络] Hibernate 的hql查询简介:http://blog.csdn.net/leaf_130/article/details/539329 ...

  7. Hibernate的hql语句save,update方法不执行

    Hibernate的hql语句save,update方法不执行 可能出现的原因问题: 未进行事务管理 需要进行xml事务配置或者注解方式的事务配置

  8. Hibernate学习---第九节:Hibernate之hql

    一.Hql 入门 1.实体类: package learn.hibernate.bean; import java.util.Date; import java.util.HashSet; impor ...

  9. Java_Web三大框架之Hibernate+jsp+HQL分页查询

    分页查询无处不在.使用Hibernate+jsp+HQL进行分页查询. 第一步:编写房屋实体类和House.hbm.xml映射. /* * 房屋实体类 */ public class House { ...

  10. Hibernate之HQL查询的一些例子

    Hibernate配备了一种非常强大的查询语言,就是HQL(hibernate query language),HQL看上去很像sql,但只是语法结构上相似,HQL是一种面向对象的查询,他可以理解继承 ...

随机推荐

  1. mysql执行计划简介

    介绍 本篇主要通过汇总网上的大牛的知识,简单介绍一下如何使用mysql的执行计划,并根据执行计划判断如何优化和是否索引最优. 执行计划可显示估计查询语句执行计划,从中可以分析查询的执行情况是否最优,有 ...

  2. IT企业如何实现项目管理信息化的目标

    随着信息化技术的不断深入,企业管理方式逐渐向信息化管理转变.大部分IT企业也为了适应企业管理方式的变革,开始加强对管理信息化创新方面的建设.而IT企业在实现信息化的进程中,项目管理信息化其实是IT企业 ...

  3. spring整合mybatis(hibernate)配置

    一.Spring整合配置Mybatis spring整合mybatis可以不需要mybatis-config.xml配置文件,直接通过spring配置文件一步到位.一般需要具备如下几个基本配置. 1. ...

  4. 作为一个懒虫,如何优雅的使用windows

    懒虫windows系列(一) 首先是快捷键,因为自己太懒了,觉得用鼠标很麻烦,下面总结一下自己最常用的快捷键(windows10 ) Ctrl+Shift+N:新建文件夹 F2:重命名 Ctrl + ...

  5. win10每次开机都显示“你的硬件设置已更改,请重启电脑……”的解决办法

    之前的系统没有这个问题,就是win10有这个问题,过一段时间就会出现这个问题,网上找了很多,最后发现是显卡驱动的问题,是A卡的问题,只需要更新A卡驱动即可,如果更新A卡驱动不行的话,或者说A卡驱动已经 ...

  6. 关于“应用程序无法启动,因为应用程序的并行配置不正确。请参阅应用程序事件日志,或使用命令行sxstrace.exe工具”问题的解决方法

    今天打开QQ管家加速版的时候突然出现了这个错误,百度了下说是系统缺少Microsoft Visual C++ 20XX(运行库),下载这个安装即可解决问题.

  7. 使用c#对MongoDB进行查询(1)

    1.BsonDocument对象 在MongoDB.Bson命名空间下存在一个BsonDocument类,它是MongoDB的文档对象,代表着MongoDB中不规则数据一条条实体模型.可以使用Bson ...

  8. 【前端单元测试入门05】react的单元测试之jest

    jest jest是facebook推出的一款测试框架,集成了前面所讲的Mocha和chai,jsdom,sinon等功能. 安装 npm install --save-dev jest npm in ...

  9. Java设计模式(六)Adapter适配器模式

    一.场景描述 “仪器数据采集器”包含采集数据以及发送数据给服务器两行为,则可定义“仪器数据采集器”接口,定义两方法“采集数据capture”和“发送数据sendData”. “PDF文件数据采集器”实 ...

  10. 第一把机械键盘 ikbc C-87

    终于入了机械键盘,ikbc C-87黑色红轴. 原本上周五晚上就到了,但是那个键盘有几个键弹起后弹簧会持续响,敲了一会,实在不能忍受,就申请换货了.新换的键盘今天终于到了,没有了之前的问题,但是几乎每 ...