博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Hibernate之HQL
阅读量:6312 次
发布时间:2019-06-22

本文共 4234 字,大约阅读时间需要 14 分钟。

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
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
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配置文件  (名字随意)

select p.id , p.name from Person p;

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

java代码:

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

 

转载于:https://www.cnblogs.com/wangliyue/p/4164261.html

你可能感兴趣的文章
Iodine:一个优秀的Java语言工具链
查看>>
戴尔开展独立软件供应商战略合作 发力云应用及大数据解决方案
查看>>
埃哲森:物联网市场潜力达万亿美元
查看>>
高德地图荣获2016金瑞奖“最具成长力产品奖”
查看>>
《数据冰山报告》显示,管理数据越来越重要
查看>>
政府运用大数据 决策告别“拍脑袋”
查看>>
亲身体验及举例来全面解析C# 异步编程
查看>>
欢迎光临阿里云栖大会SAP展区(C区301)!
查看>>
SPDK,软件定义存储的催化剂
查看>>
Tor网络已过时? 新匿名架构将达93Gb/s
查看>>
免费用流量?三大运营商流量计费系统被曝存漏洞
查看>>
Android日常开发总结的技术经验60条
查看>>
用于实时大数据处理的Lambda架构
查看>>
排查网络故障实践:解决负载均衡的难题
查看>>
关于.NET玩爬虫这些事
查看>>
IT服务持续性只适合有钱的企业吗?
查看>>
“风水逆转”:获取云端虚拟机的完整控制权其实很容易
查看>>
支付宝异常绑定 实名认证待改进
查看>>
为何思科和VMware的SDN产品总是无法很好地兼容?
查看>>
认识数据湖——拥抱开源大数据技术的前提
查看>>