热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

Hibernate查询方式

使用HQL查询数据Hibernate提供的查询方式:1、OID查询方式通过session提供的get()和load()方法加载指定的OID对象,只能按照对象的id进行查询。2、HQL查询方式通过Query接口使用HQL语言进行查询。3、QBC查询方式通过Criteria等接口和类进行查询4、本

使用HQL查询数据 Hibernate提供的查询方式: 1、OID查询方式 通过session提供的get()和load()方法加载指定的OID对象,只能按照对象的id进行查询。 2、HQL查询方式 通过Query接口使用HQL语言进行查询。 3、QBC查询方式 通过Criteria等接口和类进行查询 4、本

使用HQL查询数据

Hibernate提供的查询方式:

1、OID查询方式

通过session提供的get()和load()方法加载指定的OID对象,只能按照对象的id进行查询。

2、HQL查询方式

通过Query接口使用HQL语言进行查询。

3、QBC查询方式

通过Criteria等接口和类进行查询

4、本地SQL查询方式

使用原生SQL语言进行查询,查询结果不是结果集,而是持久化类对象。

5、对象导航查询方式

通过已经加载的对象,导航到其关联对象。

HQL是Hibernate提供的面向对象的查询语言,HQL和SQL的语法格式相似,HQL操作持久化类,而不是数据库表。

使用HQL查询步骤:

1、得到session对象。

Session session =HibernateUtil.getSessionFactory().openSession();

2、编写HQL语句。

String hql ="from Student where sname='Tom'";

3、创建Query对象。

Query query = session.createQuery(hql);

4、执行查询,得到结果。

Listlist = query.list();

注意:HQL操作的是持久化类,因此上述第二步中Student指的是持久化类Student,sname指的是持久化类属性sname,而不是数据库表的字段sname。

Query接口,是HQL查询接口,提供了各种的查询功能,相当于JDBC的Statement和PreparedStatement。可以通过session的createQuery()创建其对象。

实体查询

就是要查询持久化类的完整信息,要查询它的全部属性

例如:

from Student或者from com.po.Student通常不需要使用类的全限定名缺省时自动引入。
from Student s或from Student as s,这是为类名取别名,其中as是可选的。
where子句。from Student where sid=11070130或者fromStudent s where s.sid=11070130

where子句中可以使用各种运算符

例如:

from Student where sex=’男’ and sid<11070200
from Student where sid between 11070100 and 11070200
from Student where sname like ‘%飞’   %匹配任意长度字符
from Student where sname like  ‘_ik%’     “_”匹配单个字符,注意下划线不能进行汉字匹配。

返回查询结果可以使用Query的三个方法来实现:list(),iterate(),uniqueResult();

使用list()方法,返回查询持久化类的一个集合,而iterate()方法,直接返回持久化类的一个跌的器。

两者的区别在于:

1、查询机制不同

使用list(),查询一次即可,从数据库中检索出所有符合条件的记录,包含全部字段。

使用iterate(),首先从数据库中检索出所有符合条件的记录,仅包含id字段。然后去缓存查看缓存中是否存在这些学生信息。

a)如果缓存中包含全部数据,无需再查寻数据库,直接引用。查询1次,此时iterate()效率明显高于list()。

b)如果 缓存中不包含任何数据,需在查询数据库n次(n代表符合查询条件的记录数),依次查询各条记录,需要查询(n+1)次,此时iterate()的效率要大大的低于list()。

大多数情况下使用list()进行查询,当对象包含大量属性,或者要加载的大部分数据已经存在缓存中,可以使用iterate()。

属性查询(投影查询)

只查询持久化类的部分属性而不是全部属性

属性查询方式:

1、通过直接指定属性进行属性查询。例如:查询学生的学生编号和学生姓名。

String hql = “select sid,sname from Student”;
Query query = session.createQuery(hql);
List list = query.list();
Iterator it = list.iterator();
while(it.hasNext()){
    Object obj[]= (Object[])it.next;
    System.out.println(obj[0]+”    ”+obj[1]);
}

注意:这种查询方式List集合中的每个元素不是学生类型,而是一个对象数组,数组的长度取决于查询的属性的个数,上述示例中对象数组的长度为2,第一个元素存放学生id,第二个元素存放学生的姓名。

2、通过构造方法进行属性查询。例如:查询学生的学生编号和学生姓名。

首先为相应的持久化类提供响应的构造方法。

String hql = “select new Student(sid,sname) from Student”;
Query query = session.createQuery(hql);
List list = query.list();
Iterator it = list.iterator();
while(it.hasNext()){
    Student stu =(Student)it.next();
    System.out.println(stu.getSid()+””+stu.getSname());
}
实体更新和删除

例如:将编号为11070130学生的姓名更改为赵飞

String hql = “update Student set sname=’赵飞’ where sid=11070130”;
Query query = session.createQuery(hql);
int n = query.executeUpdate();  //n代表更新记录的个数
例如:删除学生编号为11070130的学生信息
String hql = “delete from Student where sid=11070130”;
Query query = session.createQuery(hql);
int n = query.executeUpdate();
参数绑定

使用字符串拼接缺点:性能低、安全性差、容易拼接错误。

参数绑定1:“?”占位符

    String name=”赵飞”;
    String hql=”fromStudent where sname=?”;
    Query query =session.createQuery(hql);
    query.setString(0,name);//填充的内容是什么类型的用setXXX进行填充
    Listlist = query.list();
参数绑定2:命名参数
    String name=”赵飞”;
    String hql = “fromStudent where sname=:sname”;
    Query query =session.createQuery(hql);
    query.setString(“sname”,name);
    List list = query.list();
HQL排序功能

HQL通过order by子句实现对查询结果的排序。默认升序排序。

例如:

String hql = “from Student order bysname”;
也可以指定排序策略,(asc升序、desc降序)

例如:

String hql = “from Student order bysname desc”;
order by子句可以指定多个排序条件,

例如:

String hql = “from student order bysname,sid desc”;
首先按照学生姓名进行升序排序,对于学生姓名相同的对象将按照学生编号进行降序排列。

统计函数的使用

共有5个统计函数为:avg(),sum(),min(),max(),count(),分别用来求平均数,求和,求最小值,求最大值,计数的功能。

与SQL中的统计函数不同的是:SQL中的统计韩式是用来对数据库表的字段进行操作,而HQL中的统计函数则是对持久化类的属性进行操作。

示例1:统计学生数目

String hql=”select count(*) from Student”;
Long n =(Long)session.createQuery(hql).uniqueResult();
示例2:查询所有学生的平均分、最低分、最高分。
String hql = “select avg(score),min(score),max(score)from Student”;
Object obj[] =(Object[])session.createQuery(hql).uniqueResult();
分组查询

示例:统计各个班级的学生人数

select gid,count(*) from Student group by gid;
having子句用于用于对分组结果添加查询条件。

示例:统计人数大于20的班级的学生人数

select gid,count(*) from Student  group by gid having count(*)>20
分页查询

使用Hibernate Query接口提供的方法。

1、setFirstResult()设置第一条记录的位置。

2、setMaxResult()设置最大返回的记录条数。

分页实现:

1、根据结果获得总记录数

    Query query =session.createQuery(“from Student”);
    Listlist = query.list();
    int count =list.size();
2、计算总的页数
    inttotalpages = (count%pageSize==0)?(count/pageSize):(count/pageSize+1);
3、实现分页
    query.setFirstResult((pageIndex-1)*pageSize);
    query.setMaxResults(pageSize);
    List result =query.list();
子查询

示例:查询成绩高于张华和赵飞成绩的学生信息

from Student where score >all(select score fromStudent where sname=’张华’ or sname=’赵飞’);
all的含义是分数要高于括号内所有的分数,如果题目要求查询高于张华或赵飞的成绩,应该使用any关键字。

连接查询

使用join子句实现多个持久化对象之间的联合查询。一般是针对连个持久化对象进行查询。

查询分类

\

示例,用到的数据库表为班级表和学生表,表情况如下:

\\

内连接语法:

from Entity inner join Entity.property

Entity指明了一个持久化类,Entity.propery是指明了第一个持久化类中与第二个持久化类建立关联的属性

例如:查询班级和学生中的所有匹配数据。

from Grade g inner join g.students等价于以下两个语句:from Grade g,Student s whereg=s.grade

from Grade g,Student s where g.gid=s.grade.gid;

左外连接语法

from Entity left outer join Entity.property

例如,显示班级和学生中的匹配信息,并且显示没有学生的班级

from Grade g left join g.students;

右外连接语法:

from Entity right outer join Entity.property

例如,显示班级和学生中的匹配信息,并且显示没有班级的学生信息

from Grade g right join g.students;或者

from Student s left join s.grade;


推荐阅读
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 使用C#开发SQL Server存储过程的指南
    本文介绍如何利用C#在SQL Server中创建存储过程,涵盖背景、步骤和应用场景,旨在帮助开发者更好地理解和应用这一技术。 ... [详细]
  • Windows服务与数据库交互问题解析
    本文探讨了在Windows 10(64位)环境下开发的Windows服务,旨在定期向本地MS SQL Server (v.11)插入记录。尽管服务已成功安装并运行,但记录并未正确插入。我们将详细分析可能的原因及解决方案。 ... [详细]
  • 三星W799在2011年的表现堪称经典,以其独特的双屏设计和强大的功能引领了双模手机的潮流。本文详细介绍其配置、功能及锁屏设置。 ... [详细]
  • 本文总结了汇编语言中第五至第八章的关键知识点,涵盖间接寻址、指令格式、安全编程空间、逻辑运算指令及数据重复定义等内容。通过详细解析这些内容,帮助读者更好地理解和应用汇编语言的高级特性。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 数据管理权威指南:《DAMA-DMBOK2 数据管理知识体系》
    本书提供了全面的数据管理职能、术语和最佳实践方法的标准行业解释,构建了数据管理的总体框架,为数据管理的发展奠定了坚实的理论基础。适合各类数据管理专业人士和相关领域的从业人员。 ... [详细]
  • 优化版Windows 10 LTSC 21H2企业版:适用于低内存设备
    此版本为经过优化的Windows 10 LTSC 21H2企业版,特别适合低内存配置的计算机。它基于官方版本进行了精简和性能优化,确保在资源有限的情况下依然能够稳定运行。 ... [详细]
  • 当iOS设备越狱后,某些插件可能会导致系统崩溃(白苹果)。此时,可以通过进入安全模式来排查并删除有问题的插件。本文将详细介绍如何通过特定按键组合进入不加载MobileSubstrate的安全模式,并提供相关背景知识。 ... [详细]
  • 新冠肺炎疫情期间,各大银行积极利用手机银行平台,满足客户在金融与生活多方面的需求。线上服务不仅激活了防疫相关的民生场景,还推动了银行通过互联网思维进行获客、引流与经营。本文探讨了银行在找房、买菜、打卡、教育等领域的创新举措。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 如何配置Unturned服务器及其消息设置
    本文详细介绍了Unturned服务器的配置方法和消息设置技巧,帮助用户了解并优化服务器管理。同时,提供了关于云服务资源操作记录、远程登录设置以及文件传输的相关补充信息。 ... [详细]
  • 本文探讨了如何在发布 XenApp 应用时,通过命令行参数实现启动时的参数传递。特别介绍了静态和动态参数传递的方法,并详细解释了 ICA 文件中两种参数传递方式的区别及安全检查机制。 ... [详细]
author-avatar
键盘上的泪g_752
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有