Hibernate Query Language(HQL)提供了十分强大的功能,推荐大家使用这种查询方式。HQL具有与SQL语言类似的语法规范,只不过SQL针对表中字段进行查询,而HQL针对持久化对象,它用来取得对象,而不进行update、delete和insert等操作。而且HQL是完全面向对象的,具备继承、多态和关联等特性。
1.from子句
from字句是最简单的HQL语句,例如 from Student,也可以写成select s from Student s。它简单地返回Student类的所有实例。
除了Java类和属性的名称外,HQL语句对大小写并不敏感,所以在上一句HQL语句中,from与FROM是相同的,但是Student与student就不同了,所以上述语句写成from student就会报错。下列程序演示如何通过执行from语句取得所有的Student对象。
Query query = session.createQuery(“from Student”);
List list = query.list();
for (int i=0;i<list.size(); i++)
{
Student stu = (Student)list.get(i);
System.out.println(stu.getName());
}
如果执行HQL语句“from Student, Course”,并不简单地返回两个对象,而是返回这两个对象的的笛卡儿积,这类似于SQL语句中字段的全外连接。在实际应用中,像“from Student, Course”这样的语句几乎不会出现。
2.select子句
有时并不需要得到对象的所有属性,这时可以使用select子句进行属性查询,例如,select s.name from Student s。下面程序演示如何执行这个语句:
Query query = session.createQuery(“select s.name from Student s”);
List list = query.list();
for (int i=0;i<list.size(); i++) {
String name = (String)list.get(i);
System.out.println(ame());
}
如果要查询两个以上的属性,查询结果会以数组的方式返回,如下所示:  Query query = session.createQuery(“select s.name, s.sex from Student as s”);
List list = query.list();
for (int i=0;i<list.size(); i++) {
Object obj[] = (Object[])list.get(i);
System.out.println(ame(obj[0] + “的性别是:” +obj[1]));
}
在使用属性查询时,由于使用对象数组,操作和理解都不太方便,如果将一个object[]中所有成员封装成一个对象就方便多了。下面的程序将查询结果进行了实例化:
Query query = session.createQuery(“select new Student(s.name, s.sex) from Student s”);
List list = query.list();
for (int i=0;i<list.size(); i++) {
Student stu = (Student)list.get(i);
System.out.println(stu.getName());
}
要正确运行以上程序,还需要在Student类中加入一个如下的构造函数:
public Student(String name, String sex)
{
this.name = name;
this.sex = sex;
}
3.统计函数查询
可以在HQL中使用函数,经常使用的函数有:
count():统计记录条数
min():求最小值
max():求最大值
sum():求和
age():求平均值
例如,要取得Student实例的数量,可以编写如下HQL语句:
select count(*) from Student
取得Student的平均年龄的HQL语句如下:
select avg(s.age) from Student as s
可以使用distinct去除重复数据:
select distinct s.age from Student as s
4.where子句
HQL也支持子查询,它通过where子句实现这一机制。where子句让用户缩小要返回的实例的列表范围,例如下面语句会返回所有名字为“Bill”的Student实例:
Query query = session.createQuery("from Student as s where s.name='Bill' ");
where子句允许出现的表达式包括了SQL中可以使用的大多数情况:
数学操作:+,-,*,/
真假比较操作:=,>=,<=,<>,!=,like
逻辑操作:and,or, not
字符串连接:||
SQL标量函数:例如upper()和lower()
如果子查询返回多条记录,可以用以下的关键字来量化:
all:表示所有的记录。
any:表示所有记录中的任意一条。
some:与any用法相同。
in:与any等价。
exists:表示子查询至少要返回一条记录。
例如,下面语句返回所有学生的年龄都大于22的班级对象:
from Group g where 22<all (select s.age from g.students s)
下述语句返回在所有学生中有一个学生的年龄等于22的班级:
from Group g where 22=any (select s.age from g.students s)
或者
from Group g where 22=some (select s.age from g.students s)
或者
from Group g where 22 in (select s.age from g.students s)
5.order by 子句
查询返回的列表可以按照任何返回的类或者组件的属性排序:
from Student s order by s.name asc
asc和desc是可选的,分别代表升序或者降序。
6.连接查询
与SQL查询一样, HQL也支持连接查询,如内连接、外连接和交叉连接。
inner join: 内连接
left outer join:左外连接
right outer join:右外连接
full join: 全连接,但不常用
下面重点讲解内连接查询,左外连接和右外连接查询和内连接大同小异,而全连接几乎不怎么使用。
inner join可以简写为join,例如在查询得到Group对象时,内连接取得对应的Student对象,实现的程序如下。
……//打开Session,开启事务
Student  stu = null;  //声明Student实例
Group  group = null; //声明Group实例
Query query = session.createQuery("from Group g join g.students");
List list = query.list();
Object obj[] = null;  //声明对象数组
for(int i=0;i<list.size();i++)  {
obj = (Object[])list.get(i); //取得集合中的第i个数组
group = (Group)obj[0];  //group是数组中第一个对象
stu = (Student)obj[1];   //stu是数组中第二个对象
System.out.println(stu.getName() + "属于:" +group.getName() );
}
……//提交事务,关闭Session

Hibernate Query Language(HQL)。相关推荐

  1. Hibernate查询语言(HQL)

    转自:https://www.cnblogs.com/gx-java/p/5903230.html HQL是Hibernate Query Language即Hibernate查询语言 1.执行HQL ...

  2. Hibernate 学习笔记(二)—— Hibernate HQL查询和 QBC 查询

    目录 一.Hibernate 的 HQL 查询 1.1.查询所有数据 1.2.条件查询 1.3.排序查询 1.4.统计查询 1.5.分页查询 1.6.投影查询 二.Hibernate 的 QBC 查询 ...

  3. hibernate学习笔记(总结)

    hibernate学习笔记 课程内容 6 1 HelloWorld 6 2 Hibernate原理模拟-什么是O/R Mapping以及为什么要有O/R Mapping 6 3 常见的0/R框架(了解 ...

  4. JAVAWEB开发之Hibernate详解(三)——Hibernate的检索方式、抓取策略以及利用二级缓存进行优化、解决数据库事务并发问题

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

  5. 奇怪问题:Hibernate 无法更新(update)

    今天遇到一个很奇怪的问题,我用Hibernate,更新(update)时,无法更新,没有任何报错,卡在那里半天不动,只得强制关闭. 但是有时候突然更新可以正常. 浪费了我半天时间.后来发现重启ecli ...

  6. Java, just a language (二)

    Java, just a language (二) by 梦中浮云 !声明:如果您有意愿转载本文,请在文章醒目位置注明原文链接. 在准备写第二篇之前,我花了一段时间去思考一个问题.该不该把Java的基 ...

  7. 设有一数据库,包括四个表:学生表(Student)、课程表(Course)、成绩表(Score)以及教师信息表(Teacher)。...

    一.            设有一数据库,包括四个表:学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher).四个表的结构分别如表1-1的表(一)~表( ...

  8. 把路由器啥啥从 啥啥写入 NVRAM 的命令是 (53) 。【两道题】【不知道对不对,哈哈】

    29.把路由器配置脚本从 RAM 写入 NVRAM 的命令是 (53) .[这个是配置脚本,所以找有config的呀!] (53)A.save ram nvram B.save ram C.copy ...

  9. 下面是DHCP协议工作的4种消息,正确的顺序应该是(40)。【答案】B

    下面是DHCP协议工作的4种消息,正确的顺序应该是(40). ①DHCP Discovery ②DHCP Offer ③DHCP Request ④DHCP Ack (40)A.①③②④ B.①②③④ ...

最新文章

  1. 5G时代到来,人工智能设备如何重塑TMT行业
  2. C++ 单例模式析构函数的运用,析构函数的线程安全
  3. java的hashmap排序_Java面试题:如何对HashMap按键值排序
  4. Qt Creator 代码自动补全设置
  5. 数据库:内联接,外联接,空值和联接
  6. 经典排序算法(3)——直接插入排序算法详解
  7. liblfds 测试
  8. Fragment学习2--简单的添加Fragment
  9. 01背包问题python实现
  10. POJ3122-Pie
  11. TeXworks 设置成默认用XeLaTeX排版
  12. 怎么用计算机求logo,小学计算机教学中的LOGO语言教学(转载)
  13. 字体属性html语言,html字体属性face
  14. phpStudy安装框架教程
  15. 大学生数学竞赛资料目录20190403更新
  16. MySQL 8.0版本连接报错:Could not create connection to database server.
  17. PTA:7-46 新浪微博热门话题 (30 分)
  18. HTML代码 可在线运行查看效果的HTML在线编辑器
  19. gridView---->列标题右键菜单管理
  20. 入门级带你实现一个安卓智能家居APP(2)kotlin版本

热门文章

  1. C++尽可能使用const
  2. QT的QGraphicsProxyWidget类的使用
  3. QT的QDrag类的使用
  4. 安装python应该先安装pycharm还是python_Pycharm及python安装详细步骤及PyCharm配置整理(推荐)...
  5. php 开启imagick,PHP-Imagick:在Imagick项目上设置重力
  6. datax安装+配置+使用文档
  7. 第十七天:规划沟通管理
  8. Spring MVC中jsessionid所引起的问题 和解决
  9. 文件加解密,文件操作
  10. 开源的ESB产品列表信息