- 浏览: 103062 次
- 性别:
- 来自: 北京
-
文章分类
最新评论
提供的检索方式:
(1)导航对象图检索方式
(2)OID检索方式
(3)HQL检索方式
(4)QBC检索方式[query by Criteria(标准)]
(5)本地SQL检索方式
1、简介
1.1 HQL检索方式
HQL(Hibernate query Language)是面向对象的查询语言,在Hibernate提供的检索方式中,HQL是使用最广泛的检索方式。功能:
a.在查询语句中设定各种查询条件
b.支持投影查询,即仅检索出对象的部分属性
c. 支持分页查询
d.支持连接查询
e.支持分组查询,允许使用having 和group by 关键字
f.提供内聚聚集函数,如sum(),min()和max()
g.支持子查询,即嵌入式查询
h.支持动态帮定参数
session的find方法以及Query 接口都是支持HQL检索方式的,这两者的区别在于,前者只是执行一些简单的HQL查询语句的便捷方式,它不具有动态邦定参数的功能,Query 接口才是真正的HQL查询接口。
//创建一个Query 对象
Query query = session.createQuery ("from Customer as c where c.name=:customerName and c.age=:customerAge");
//动态绑定参数
query.setString("customerName","Tom");
query.setInteger("customerAge",21);
//执行查询语句,返回结果
List result = query.list();
1.2 QBC检索方式
QBC提供的查询方式由:Criteria接口,Criterion接口和Expression类组成,支持在运行时动态生成查询语句。
//创建一个 Criteria对象
Criteria criteria = session.ceateCriteria(Customer.class);
//设定查询条件,然后把查询条件加入到Criteria中
Criterion criterion1 = Exception.like("name","T%");
Criterion criterion2 = Exception.eq("age",new Integer(21));
criteria = criteria.add(criterion1);
criteria = criteria.add(criterion2);
//执行查询语句,返回查询结果
List result = criteria.list();
QBE(Quary by Example)检索方式,是QBC的子功能。它允许先创建一个对象样板,然后检索出所有和这个样板相同的对象。
//创建一个Customer样板对象
Customer example = new Customer();
example.setAge(21);
List result = session.createCriteria(Customer.class)
.add(Example.create(example0)
.list();
1.3 SQL检索方式
HQL和QBC检索时,Hibernate会生成标准的SQL查询语句,适用于所有的数据库平台,这两种方式都是跨平台的。
有的应用程序可能需要根据底层数据库的SQL方言,来生成一些特殊的查询语句,这样可以利用SQL查询方式。
Query query = session.createSQLQuery("select {c.*} from CUSTOMERS c where c.NAME like :customerName and c.AGE = :customerAge ","c",Customer.class);
query.setString("customerName","T%");
query.setInteger("customerAge",21);
List result = query.list();
1.4 ....
1.5 适用别名
from Customer as c where c.name=:name
= from Customer c where c.name=:name
1.6 多态查询
HQL和QBC都支持多态查询,多态查询是指查询出当前类及所有子类的实例,
session.createQuery("from Employee"); or session.createCriteria(Employee.class);
如果Employee类有两个子类:HourlyEmployee和SalariedEmployee,那么这个查询语句会查出所有的Employee实例,以及HourlyEmployee类和SalariedEmployee类的实例。
session.createQuery("from HourlyEmployee");
session.createCriteria(HourlyEmployee.class);//只检索子类
1.7 对查询结果排序
HQL采用 order by ,QBC采用Order类对结果排序
//HQL
Query query = session.createQuery("from Customer c order by c.name");
//QBC
Criteria criteria = session.createCriteria(Customer.class);
criteria.addOrder(Order.asc("name"));
1.8 分页查询
Query和Criteria接口都提供了用于分页显示查询结果的方法
a.setFirstResult(int firstResult): 开始索引位置(从0开始)
b.setMaxResult(int maxResults):一次最多检索出的对象数目
1.9 检索单个对象
Query和Criteria接口都提供了以下用于执行查询语句并返回查询结果的方法。
a. list方法:返回一个list类型的查询结果(setMaxResult(1)即返回单个对象)
b. uniqueResult()方法:返回单个对象
1.10 在HQL查询语句中绑定参数
Hibernate参数机制依赖于JDBC API中的PreparedStatement的预定义SQL语句功能。优点:
a. 非常安全,
b. 能够利用底层数据库预编译SQL语句的功能,提高查询数据的性能。预编译是指底层数据库系统只需编译SQL语句一次,把编译出来的可执行代码保存在缓存中,如果多次执行相同形式的SQL语句,不需要重新编译,只需要从缓存中获得执行代码即可。(而如果使用条件拼sql会每次都重新编译。)
1.10.1 参数绑定的形式
a.按照参数名字绑定,命名参数以":"开头。eg:c.name=:name
b.按照参数位置绑定,用?来定义参数的位置。eg:c.name=?
按名字绑定的优势:
a. 使程序代码有较好的可读性
b.按名字绑定有利于程序代码的维护,而对于按位置绑定方式,如果参数在HQL查询语句中的位置改变了,就必须修改相关帮定参数的代码,这削弱了程序代码的健壮性和可维护性。
c. 按名字绑定方式允许一个参数在HQL查询语句中出现多次。
1.10.2 绑定各种类型的参数
a.setXxxxx(),如:setInteger();
b.三个特殊的参数绑定方法
-->setEntity():把参数与一个持久化类的实例绑定,主要是用其中的OID进行查询
session.createQuery("from Order o where o.customer= :customer")
.setEntity("customer",customer)
.list();
对应的SQL:
select * from ORDERS where CUSTOMER_ID=1;
-->setParameter()方法:绑定任意类型的参数
query.setParameter("customer",customer,Hibernate.entity(Customer.class));
query.setParameter("orderNumber",orderNumber,HIbernate.STRING);
//某些类型Hibernate可以根据参数值的java类型推断出对应的映射类型,此时不需要显示指定一个摄类型
query.setParameter("orderNumber",orderNumber);
但是日期类型的一般要指定,因为有好几种可能
-->setProperties()方法:用于把命名参数与一个对象的属性值绑定
Customer customer = new Customer();
customer.setName("Tom");
customer.setAge(21);
Query query = session.createQuery("from Customer as c where c.name=:name and c.age=:age");
query.setProperties(customer);
:name 会和Customer对象的name属性匹配。
1.11 在映射文件中定义命名查询语句
<hibernate-mapping>
<class name="mypack.Customer" table="CUSTOMERS">
...
</class>
<query name="findCustomersByName"><![CDATA[
from Customer c where c.name like :name
]]></query>
</hibernate-mapping>
<query>元素用于定义一个HQL查询语句,他和<class>元素并列,程序中使用方式:
Query query = session.getNameOfQuery("findCustomersByName");
query.setString("name",name);
List result = query.list();
<query>元素也可以用于定义一个本地SQL语句
2、设定查询条件
HQL查询通过where子句来设定查询条件,注意的是 from Customer c where c.name ='tom',注意的是,在where子句中给出的是对象的属性名,而不是字段名.
对于QBC查询,必须创建一个Criterion对象来设定查询条件,Expression类提供了创建Criterion实例的工厂方法。
2.1 比较运算
2.2 范围运算
in、between ... and ...、等
2.3 字符串模式匹配
通配符:
%:匹配任意类型并且任意长度(可以=0)的字符串,如果是中文,需要两个百分号,即"%%"
_:匹配单个任意字符,常用来限制字符串的表达式长度。
2.4 逻辑运算
3、连接查询
和SQL查询一样,HQL与QBC也支持各种各样的连接查询,如内连接、外连接和交叉连接,HQL和QBC还支持迫切内连接和迫切左外连接。
迫切左外连接和迫切内连接不仅指定了连接查询方式,而且显式指定了关联级别的检索策略。
3.1 默认情况下关联级别的运行时检索策略
3.2 迫切左外连接
----会采取迫切左外连接检索策略----
//HQL
Query query = session.createQuery("from Customer c left join fetch c.orders o where c.name like 'T%'");
List result = query.list();
//QBC检索方式
List result = session.createCriteria(Customer.class)
.setFetchMode("orders",FetchMode.EAGER)
.add(Expression.like("name","T",MatchMode.START))
.list();
HQL:left join fetch 关键字表示迫切左外连接检索策略。
QBC:FetchMode.EAGER表示迫切左外连接检索策略。所有的orders集合都被初始化,且返回的Customer对象集合中可能有重复的元素,可以使用HashSet来过滤:
HashSet set = new HashSet(result);
3.3 左外连接
//HQL
Query query = session.createQuery("from Customer c left join c.orders o where c.name like 'T%'");
List result = query.list();
for(Iterator pairs = result.iterator();pairs.hasNext();){
Object[] pars = (Object[])pairs.next();
Customer customer = (Customer)pairs[0];
Order order =(Order)pairs[1];
}
根据映射文件来决定orders集合的检索策略
注:返回结果中与迫切左外连接的不同,迫切左外连接,返回customer,这里返回是对象数组(一行数据拆成了两个对象)
如果希望返回的集合中仅包含Customer对象,可以在HQL查询语句中使用select关键字:
session.createQuery("select c from Customer c left join c.orders o where c.name like 'T%'");
但初始化orders的时间由映射文件决定
3.4 内连接
同样可以设定select 关键字来使得之返回Customer对象。
QBC也支持内连接查询:
Criteria customerCriteria = session.createCriteria(Customer.class);
customerCriteria.add(Expression.like("name","T",MatchMode.START));
Criteria orderCriteria = customerCriteria.create(Criteria("orders"));
orderCriteria.add(Expression.like("orderNumber","T",MatchMode.START));
List result = orderCriteria.list();
另:等价于
List result = session.createCriteria(Customer.class)
.createAlias("orders","o")
.add(Expression.like("this.name","T",MatchMode.START)//Customer的默认别名=this
.add(Expression.like("o.orderNumber","T",MatchMode.START))
.list();
默认情况下,QBC只检索出Customer对象,以上代码等价于H
===>select c from Customer c join c.orders o where c.name like 'T%' and o.orderNumber like 'T%'
3.5 迫切内连接
session.createQuery("from Customer c inner join fetch c.orders o where c.name like 'T%'");
如果包含重复元素也可以用HashSet来过滤。
注: QBC不支持迫切内连接
3.6 隐式内连接
HQL:
通过o.customer.name的形式访问与Order关联的Customer对象的name属性
from Order o where o.customer.name like 'T%'
以上代码虽然没有使用join关键字,它隐式指明使用内连接查询,他和一下HQL查询语句等价:
from Order o join o.customer c where c.name like 'T%'
QBC:
不支持隐式内连接,必须显式指定
3.7 右外连接
3.8 使用SQL风格的交叉连接和隐式内连接
HQL支持SQL风格的交叉连接查询,eg:
from Customer,Order
这个SQL执行交叉连接查询,将返回CUSTOMERS表与ORDERS表的交叉组合。(n*m条结果)
HQL内连接查询语句:
from Customer c inner join c.orders ;
如果Customer没有orders集合属性,可以采用SQL风格的隐式内连接查询语句:
from Customer c ,Order o where c.id = o.customer_id
3.9 关联级别运行时的检索策略
总结:
(1)如果在HQL或QBC程序代码中没有显示指定检索策略,将使用映射文件配置的检索策略,但有个例外,即HQL总是忽略映射文件中设置的迫切左外连接检索策略。也就是说,及时映射文件中设置了迫切左外连接检索策略,如果HQL查询语句中没有显示指定这种策略,那么HQL仍然采用立即检索策略。
(2)如果在HQL或QBC程序代码中显示指定了检索策略,就会覆盖映射文件配置的检索策略。
在HQL查询语句中显示指定的检索策略包括以下内容:
a. left join fetch
b. inner join fetch
QBC中FetchMode类的三个静态实例,指定检索策略
a.FetchMode.DEFAULT:默认值,采用映射文件中配置的检索策略。
b.FetchMode.EAGER:迫切左外连接
c. FetchMode.LAZY:显示指定延迟检索。(HQL中没有提供该功能)
(3)只允许在一个sql语句中迫切左连接检索一个集合(一对多或多对多关联),允许在一个查询语句中迫切左连接检索多个一对一关联或着多对一关联
(4)HQL支持的各种连接查询
发表评论
-
Hibernate入门
2010-10-27 00:11 735Java代码 1.public class User { ... -
hibernate二级缓存攻略
2010-10-20 15:31 617很多人对二级缓存都不太了解,或者是有错误的认识,我一直想写一篇 ... -
精通hibernate学习笔记(8-2)[检索方式]
2010-10-19 13:01 7414、报表查询 报表查询用于对数据分组和统计,完整的HQL语 ... -
精通hibernate学习笔记(7)[检索策略]
2010-10-19 12:55 810Customer和Order为例 1、hibernate检索 ... -
精通hibernate学习笔记(6)[映射类型]
2010-10-19 12:51 776Hibernate映射类型分为两种:内置映射类型和客户化映射类 ... -
精通hibernate学习笔记(4)[操作持久化对象]
2010-10-19 12:47 7141、理解Session的缓存 如果希望一个java对象一直处 ... -
精通hibernate学习笔记(5)[映射组成关系]
2010-10-19 12:46 8781、概念 1.1 聚集关系 在域模型中,有些类由几个 ... -
精通hibernate学习笔记(3)[关联关系]
2010-10-19 12:43 930关联关系分:单向关联 ... -
精通hibernate学习笔记(2)[标志符生成器]
2010-10-19 12:37 5941、increment 标识符生成器 该生成器由Hiber ... -
精通hibernate学习笔记(1)
2010-10-19 12:36 774实体域对象的 持久化模式 1、ORM模式 对象-关 ... -
分析Hibernate的缓存机制
2010-10-19 12:33 628缓存是介于应用程序和 ... -
Hibernate缓存管理
2010-10-19 12:31 6081. Cache简介: 缓存( ... -
Hibernate 学习笔记
2010-10-19 12:28 805原创 hibernate 笔记 收藏 day1 一. h ...
相关推荐
Hibernate学习笔记 Hibernate学习笔记 Hibernate学习笔记 Hibernate学习笔记
Hibernate学习笔记整理 以下是 Hibernate 框架的详细知识点: Hibernate 介绍 Hibernate 是一个 ORM(Object-Relational Mapping)框架,用于将 Java 对象映射到数据库表中。它提供了一个简洁的方式来访问和操作...
《Hibernate学习笔记特别详细》 Hibernate,作为一款开源的Object-Relational Mapping(ORM)框架,为Java开发者提供了强大的数据库操作支持。它简化了数据库访问的复杂性,使得开发人员可以像操作对象一样操作...
hibernate 学习笔记精要hibernate 学习笔记精要hibernate 学习笔记精要hibernate 学习笔记精要
在本篇《Hibernate学习笔记》中,我们将深入探讨Hibernate这一流行的Java对象关系映射(ORM)框架。Hibernate允许开发者以面向对象的方式处理数据库操作,极大地简化了数据存取的复杂性。以下是一些关键知识点: 1....
这套笔记是我学习Hibernate,进行相关技术点训练时记录下来的,其中包括技术点说明与相关事例,拿出来与大家分享。
【标题】:“精通Hibernate读书笔记” 【描述】:本笔记主要涵盖了Hibernate的使用、概念以及在Java应用程序中的重要性。 【标签】:Hibernate 【正文】: Hibernate是Java应用程序与关系数据库之间的一种中间件...
【Java相关课程系列笔记之十四Hibernate学习笔记】 Hibernate是一个开源的对象关系映射(ORM)框架,它极大地简化了Java应用程序对数据库的操作。本笔记将详细阐述Hibernate的核心概念、使用方法和特性。 一、...
《Hibernate学习笔记——马士兵教程解析》 在Java开发领域,ORM(Object-Relational Mapping)框架的使用已经非常普遍,其中Hibernate作为一款优秀的ORM框架,因其强大的功能和易用性深受开发者喜爱。本文将根据马...
hibernate概述,hibernate入门Demo,hibernate配置文件详解(全局配置,实体类映射配置),配置...hibernate查询方式概述,HQL查询,QBC查询,分页,结果集封装方式 ,高级查询 查询的优化,一级缓存,二级缓存,批量查询,注解方式
### 马士兵Hibernate学习笔记知识点总结 #### 一、课程内容概览 - **HelloWorld**:通过简单的示例程序介绍如何启动一个基于Hibernate的Java项目。 - **Hibernate原理模拟**:解释O/R Mapping的概念及其重要性。 -...
精通hibernate 完整版 力荐学习hibernate的学习用书
**Hibernate学习笔记与总结** Hibernate 是一款开源的对象关系映射(ORM)框架,它为Java开发者提供了一种在关系数据库上操作对象数据的便捷方式。本文将深入探讨Hibernate的核心概念、配置、实体类、映射文件、...
传智播客 汤阳光 Hibernate 学习笔记,非常详细的hibernate学习资料!
### Hibernate 学习笔记知识点概览 #### 一、Hibernate 概述 - **定义**:Hibernate 是一款开源的对象关系映射(ORM)框架,它实现了将 Java 应用程序中的对象模型映射到关系型数据库中的记录。通过 ORM 技术,...
在深入探讨Hibernate学习笔记第二天的源码之前,我们先来理解一下Hibernate的核心概念。Hibernate是一个开源的对象关系映射(ORM)框架,它允许Java开发者将数据库操作转化为对象模型,大大简化了数据访问层的开发...
这篇文档和学习笔记将深入介绍Hibernate的核心概念、API用法以及最佳实践。 1. **Hibernate核心概念** - **对象关系映射(ORM)**: Hibernate是ORM的一种实现,它允许开发者使用面向对象的方式来操作数据库,而...