Hibernate框架学习---HQL数据查询基础

HQL定义

HQL全称为(Hibernate Query Language)

HQL是面向对象的查询语言(即以面向对象的角度进行查询),虽然HQL的语句形式与SQL很相近,但它查询的主体是映射配置的持久化类及其属性,与SQL查询主体是数据库表是完全不同的,除此之外,从数据库查询方面的功能上来讲,SQL能实现的数据库查询功能,HQL几乎可以同样实现。实际上作为一个ORM(Object Relation Mapping)对象关系映射框架,Hibernate框架会将编写好的HQL语句解析成SQL语句来完成最终的数据库查询操作。

HQL语句形式

【1】select...指定查询结果中的对象和属性,并指定以何种数据类型来返回,位置在HQL语句中排在最前面。
【2】from...指定HQL语句的查询目标,必须项(映射配置的持久化类及其属性)
【3】where...逻辑表达式,设置查询的条件,限制返回查询结果的范围
【4】group by...分组查询子句
【5】having...对分组条件进行限制
【6】order by...指定查询结果中实例对象的排序

HQL要注意的问题

【1】HQL是面向对象的查询语言,查询主体是持久化类,对Java类与属性大小写敏感。(SQL查询主体是数据表,表名和属性名是不敏感的)

【2】HQL对关键字不区分大小写(规范关键字都小写)。

Query接口简介

org.hibernate.Query接口
1.Query接口中有定义执行查询的方法,该方法完成了HQL语句的解析和执行过程,并返回查询的结果(就像sql语句如果没有了jdbc接口,它也只是一个字符串变量,HQL也一样,hibernate负责解析HQL语句,然后根据我们的映射配置信息,把HQL语句解析成相应的SQL语句,来执行数据库的查询操作,这一个过程的完成依靠的就是Query接口)。

2、Query接口支持方法链编程风格,使得程序代码更为简洁(简单来说就是调用方法后,返回的方法结果还是调用方法的这个对象,我们可以调用方法后,调用该对象的其他方法,这样我们就可以用一条程序语句完成多个方法的调用和执行)。适用场景:查询参数是动态设置的,特别是多个参数的设置。

Query实例的创建

【a】通过Session接口的createQuery()方法创建Query实例。

【b】createQuery方法包含一个HQL语句参数,该参数就是要执行的HQL查询语句。


image.png

Query执行查询

【a】Query接口的list()方法执行HQL查询。

【b】list()方法查询完之后,返回结果数据类型为java.util.List,List集合中存放符合查询条件的持久化对象。

Query query=session.createQuery("from Student");
List<Student> list=query.list();
for(List l:list){
System.out.println(l);
}

HQL语句

from字句
from子句是HQL语句的最简形式
from指定了HQL语句查询主体-持久化类及其属性
当编写的HQL中只有from子句,默认Hibernate框架会查询该持久化类的所有实例以及属性.
from也可以实现一个与其他表有关联的表的查询.(不是多表查询,属于单表)
默认情况下,hibernate是不做外键的查询操作的,当需要用到外键是才会去查询外键所对应的持久类,在控制台输出语句中,已经输出过的外键所对应的持久类查询sql语句不再重复输出。
from子句中持久化类的引用
1、from子句引入持久化类,不需要引入持久化类的全限定名,直接引入类名。
2、auto-import(自动引入)缺省情况:hibernate框架中解析HQL语句时,会根据映射配置信息,自动完成持久化类的导入。

image.png

select字句
1.使用select指定检索数据以Object[]方式返回查询结果(使用select子句进行查询,可以减少无用的数据传输量)
如果select子句中只是指定了查询的对象和属性,但是没有指定返回的数据类型,默认的查询结果以Object[]形式返回。
注意:当仅指定一个字段时,返回的是对象而不是对象数组。
image.png

2.以List形式返回查询结果 : new list(...)
String hql = "select new list(s.name,s.tel) from Seller s";
查询结果:
List<List> list = query.list();


image.png

3.定义:select子句中使用new map指定查询结果的数据类型为map,并需要注意在获取值时,Map中的key值为属性在select语句中的相应索引值(从0开始),并且类型为字符串类型。
通过select子句指定返回结果类型为Map

String hql = "select new map(s.name as name,s.tel) from Seller as s";
Query query = session.createQuery(hql);


image.png

4.以自定义类型返回查询结果:
1、在持久类中定义对应参数的构造方法
2、在select语句中使用构造方法

String hql = "select new Seller(s.name as name,s.tel) from Seller s";
Query query = session.createQuery(hql);
List<Seller> sellers = query.list();

image.png

通过distinct返回不重复的查询结果

distinct关键字
去除查询结果中的重复元素。

当使用select语句以后,查询结果中的元素就不再保证是唯一的了,比如查询客户持久化类的时候,选择返回性别元素(select sex from Customer c),这时返回的结果就会发生重复,而在一个查询结果中,有两个相同的行,是没有意义的,这时就可以使用distinct关键字(select distinct sex from Customer c)消除查询结果中重复的元素。

image.png

where字句
比较运算:持久化类的属性与给定的查询条件进行比较。
1、比较运算符:=、<>、<、>、>=、<=。
2、null值判断————is [not] null,HQL中允许使用相等和不等进行null值判断,Hibernate框架会将x=null解析成x is null,x<>null解析成x is not null。

范围运算
判断属性值是否在给定的条件范围之内。

1、[not] in (列表)————进行的范围运算,in关键字后为候选值列表,该候选值列表可以明确指出也可以是子查询,当属性值在候选列表中存在返回true,否则返回false。

2、[not] between 值1 and 值2————指定一个值的范围,只要属性值在这个范围内,该运算就返回true值,否则返回false。
案例:通过in关键字查询用户年龄20和40的用户


image.png

案例2:查询年龄在20到40之间的用户


image.png

字符串模式匹配
通过使用like关键字和通配符,对字符串类型的属性进行匹配运算(模糊查询)。

通配符:%、。一个%形式可以匹配任意个字符,一个形式匹配一个字符。
案例:查询顾客名字姓张的,并且有两个字的用户。

案例2:查询地址在北京的顾客信息(因为北京在地址中不固定,所以使用%通配符)


image.png

逻辑运算
通过逻辑运算符,将逻辑表达式按照逻辑运算规则,形成一个新的逻辑表达式。

逻辑运算符:and(逻辑与)——如果逻辑表达式运算结果都为true则为true否则就为false、or(逻辑或)——如果逻辑表达式运算结果都为false则为false否则就为true、not(逻辑非)——对布尔运算结果取反。
集合运算
HQL语句提供比较特殊的运算符,持久化映射中,存在一对多的映射配置,这里就可以使用集合运算符做相应的判定运算。
集合运算符:Hibernate框架会在hql解析过程中,解析成相应sql语句时

把empty——>exists把member of——>in运算。
1、is [not] empty判断集合类型属性[不]为空,不包含任何元素。

2、member of判断实例是否属于该集合
查询订单明细不为空的有效订单


image.png

四则运算(+、-、、/)
1、HQL语句中也可以使用+、-、
、/四则运算。

2、四则运算可以在where子句和select子句中使用
查询单个对象
1、Query接口定义了uniqueResult方法,该方法强制返回结果只存在一个实例对象,而不再返回list集合形式的查询结果。

2、使用uniqueResult方法注意,通过where子句设置恰当的条件,保证符合查询条件的实例对象仅有一个,或者不存在,如果设置的查询条件不当,查询返回的实例对象多余一个,该方法就会抛出异常,终止运行。


排序——order by子句
1、使用order by子句对查询结果排序,默认使用升序排序。
【a】升序排序——asc

【b】降序排序——desc
查询商品价格按升序返回查询结果


image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,525评论 6 507
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,203评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,862评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,728评论 1 294
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,743评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,590评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,330评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,244评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,693评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,885评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,001评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,723评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,343评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,919评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,042评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,191评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,955评论 2 355