- 浏览: 519375 次
- 性别:
- 来自: 上海
文章分类
- 全部博客 (278)
- java (41)
- 设计模式 (4)
- sql (10)
- webservice (2)
- spring (9)
- struts (6)
- struts2 (32)
- hibernate (27)
- Struts_hibernate_Spring整合 (4)
- Velocity (1)
- Servlet (9)
- JSP (6)
- javascript (19)
- jquery (10)
- ajax (4)
- html、xml (3)
- JDBC (2)
- JDK (6)
- mysql (2)
- oracle (11)
- SqlServer (1)
- DB2 (4)
- tool (7)
- linux (5)
- UML (1)
- eclipse (8)
- 执行文件 (1)
- 应用服务器 (4)
- 代码重构 (1)
- 日本語 (19)
- 交规 (1)
- office (9)
- firefox (1)
- net (1)
- 测试 (1)
- temp (6)
- 对日外包 (1)
- windows (1)
- 版本控制 (1)
- android (2)
- 项目管理 (1)
最新评论
Hibernate的检索策略包括类级别检索策略和关联级别检索策略。
类级别检索策略
有立即检索和延迟检索,默认的检索策略是立即检索。在Hibernate映射文件中,通过在<class>上配置 lazy属性来确定检索策略。对于Session的检索方式,类级别检索策略仅适用于load方法
;也就说,对于get、qurey检索,持久化对象都会被立即加载而不管lazy是false还是true.
一
般来说,我们检索对象就是要访问它,因此立即检索是通常的选择。由于load方法在检索不到对象时会抛出异常(立即检索的情况下),因此我个人并不建议使
用load检索;而由于<class>中的lazy属性还影响到多对一及一对一的检索策略,因此使用load方法就更没必要了。
例如:Customer.hbm.xml
<class name="mypack.Customer" table="CUSTOMERS" lazy="true"></class>
立即加载:
Customer customer = (Customer)session.load(Customer.class,new Long(1));
当上面一条语句执行到时,hibernate会立即输出以下语句:
select * from customers where id = 1;
这个时候customer就已经实例化了。
延迟加载:
Customer customer = (Customer)session.load(Customer.class,new Long(1));
上面语句执行到时hibernate不会立即查询customer表,而是返回customer类的代理类的实例。
这个代理类有以下的特征:
1)Hibernate在运行时动态生成,它扩展了customer类,因此它继承了customer的所有属性和方法,但是它的实现对于应用程序是透明的。
2)当hibernate创建customer代理类实例时,仅仅初始化了它的OID,其他属性都为null,因此这个代理类占用的内存很少。
3)当程序第一次访问代理类的实例时(如调用 customer.getXXX()或customer.setXXX()方法),hibernate会初始化代理类实例,这时才真正区数据库查询。但是 如果仅仅是方位代理类的getId(),hibernate仍然不会区访问数据库。
以上讨论的是类级别load的检索策略,如果是使用session的get 和 find接口进行数据查询的话不关class的检索策略设置为什么都会使用立即检索策略。
如果使用load进行查询(不关是立即加载还是延迟加载),都会生成customer的代理类实例,这样我们在判断customer==null时就一定为false,而不能准确的知道数据库中是否存在这样的实例。
另外:以下会抛出异常
tx = session.beginTransaction(); Customer customer = (Customer)sesson.load(Customer.class,1); tx.commit(); session.close(); cusomer.getName;
应改成:
tx = session.beginTransaction(); Customer customer = (Customer)sesson.load(Customer.class,1); if(!Hibernate.isInitialized(customer)){ Hibernate.initialize(customer); } tx.commit(); session.close(); cusomer.getName;
关联级别检索策略
有立即检索、延迟检索和迫切左外连接检索。对于关联级别检索,又可分为一对多和多对多、多对一和一对一两种情况讨论。
一对多和多对多关联关系一般使用<set>配置。<set>有lazy和outer-join属性,它们的不同取值绝对了检索策略。
1)立即检索:这是一对多默认的检索策略,此时lazy=false,outer-join=false.尽管这是默认的检索策略,但如果关联的集合是无用的,那么就不要使用这种检索方式。
2)延迟检索:此时lazy=true,outer-join=false(outer-join=true是无意义的),这是优先考虑的检索方式。
3)迫切左外连接检索:此时
lazy=false,outer-join=true,这种检索策略只适用于依靠id检索方式(load、get),而不适用于query的集合检索
(它会采用立即检索策略)。相比于立即检索,这种检索策略减少了一条sql语句,但在Hibernate中,只能有一个<set>配置成
outer-join=true.
多对一和一对一检索策略一般使用<many-to-one>、<one-to-one>配置。<many-
to-one>中需要配置的属性是
outer-join,同时还需要配置one端关联的<class>的lazy属性(配置的可不是<many-to-one>中
的lazy哦),它们的组合后的检索策略如下:
1) outer-join=auto:这是默认值,如果lazy=true为延迟检索,如果lazy=false为迫切左外连接检索。
2) outer-join=true,无关于lazy,都为迫切左外连接检索。
3) outer-join=false,如果lazy=true为延迟检索,否则为立即检索。
可以看到,在默认的情况下(outer-join=auto,lazy=false),对关联的one端对象Hibernate采用的迫切左外连接检索。
依我看,很多情况下,我们并不需要加载one端关联的对象(很可能我们需要的仅仅是关联对象的id);另外,如果关联对象也采用了迫切左外连接检索,就会
出现select语句中有多个外连接表,如果个数多的话会影响检索性能,这也是为什么Hibernate通过
hibernate.max_fetch_depth属性来控制外连接的深度。对于迫切左外连接检索,query的集合检索并不适用,它会采用立即检索策
略。
对于检索策略,需要根据实际情况进行选择。对于立即检索和延迟检索,它们的优点在于select语句简单(每张表一条语句)、查询速度快,缺点在于关联表
时需要多条select语句,增加了访问数据库的频率。因此在选择即检索和延迟检索时,可以考虑使用批量检索策略来减少select语句的数量(配置
batch-size属性)。对于切左外连接检索,优点在于select较少,但缺点是select语句的复杂度提高,多表之间的关联会是很耗时的操作。
另外,配置文件是死的,但程序是活的,可以根据需要在程序里显示的指定检索策略(可能经常需要在程序中显示指定迫切左外连接检索)。为了清楚检索策略的配
置效果如何,可以配置show_sql属性查看程序运行时Hibernate执行的sql语句。
一。 一对多和多对多关联检索策略
1.
<set name="orders" inverse="true" lazy="true" batch-size="3"> <key column="CUSTOMER_ID"></key> <one-to-many class="mypack.Order"/> </set>
batch=size="3"为批量延迟检索,假如共有4条记录。此时会批量初始化3个orders,第4个是延迟加载。
如果没有batch=size 属性 4条记录 全部为延迟加载!
2. 迫切左外连接检索
<set name="orders" inverse="true" outer-join="true"></set>
当Session 的 get() 方法时,执行一下
select * from CUSTOMERS left outer join ORDERS on CUSTOMERS .id=ORDERS .CUSTOMER_ID where CUSTOMERS.ID = 1;
注意,outer-join="true"对于 Session 的 find(hql) 无效!!!
二。多对一和一对一关联的检索策略
看 hibernate检索策略(类级别检索,关联基本检索,延迟加载...)(二)
发表评论
文章已被作者锁定,不允许评论。
-
Hibernate 配置 说明
2011-11-29 09:05 1481Hibernate配置说明 <?xm ... -
hibernate 相关问题 (一)
2011-04-06 13:50 1468一、Hibernate缓存深入详解 看附件 ... -
Hibenrate 中 inverse="true"
2010-09-19 10:12 1060转:http://www.iteye.com/to ... -
hibernate 3.0 中 批量更新,批量删除
2010-09-09 12:51 981hibernate 2.1没有对批量更新和批量删除提供很好的支 ... -
hibernate one-to-one
2010-09-07 15:56 1427一。 1. 完全的一对一关系,即A与B两种实体,分两个表格, ... -
hibernate many-to-many
2010-09-07 15:26 884Inverse是hibernate双向关系 ... -
hibernate 集合排序 二 (数据库排序)
2010-09-03 11:03 1144<set><idbag>< ... -
hibernate 集合排序 一 (内存排序)
2010-09-03 10:52 1085内存中排序 <set><map ... -
hibernate map映射
2010-09-03 10:46 1024Person.java package com.aa ... -
hibernate list映射
2010-09-03 10:41 1117Answer类为Question类一对多关联关系,即一个问题对 ... -
hibernate idbag映射
2010-09-03 10:35 1051假设Team和Student是1对多的关系,而studen ... -
hibernate set映射
2010-09-03 10:27 1796Hibernate之容器映射 Set映射 两张表对应一个 ... -
hibernate 二级缓存(三)
2010-08-31 11:00 1370过这篇文章纪录hibernate二级缓存的一些使用经历,利用几 ... -
hibernate 二级缓存(二)
2010-08-31 10:48 11441 启用 Hibernate 二级缓存 Hibe ... -
hibernate 二级缓存(一)
2010-08-31 10:29 1848一。 1 . Hibernate ... -
hibernate 事务 并发
2010-08-27 10:17 1387数据库事务与并发 ... -
hibernate 执行 本地 sql
2010-08-25 10:47 17491.为了把sql查询返回的关系数据映射为对象,需 ... -
Hibernate3的配置参数汇总
2010-08-25 10:22 7561、Hibernate JDBC属性 属 ... -
正确理解 hibernate 的 inverse many-to-many
2010-08-25 10:18 822Inverse是hibernate双向关系 ... -
Hql 语法
2010-08-19 14:40 922HQL是完全面向对象的查询语言,因此可以支持继承和多态等特征。 ...
相关推荐
标题:“HIBERNATE检索策略” 描述:本文深入解析了HIBERNATE的检索策略,为读者提供了一条清晰的学习路径,重点分析了HIBERNATE中的抓取策略及其应用场景,帮助开发者更有效地管理和优化数据加载过程。 在...
Hibernate支持两种主要的检索策略:类级别检索策略和关联级别检索策略。 #### 二、类级别检索策略 类级别检索策略是指当查询一个实体类时,如何加载该实体类中的属性和关联关系。这通常涉及到单个实体的加载方式,...
一、Hibernate检索方式 1. **HQL(Hibernate Query Language)**: HQL是Hibernate提供的面向对象的查询语言,类似于SQL,但它是基于类和对象的。你可以通过HQL来查询、更新和删除对象,而无需关心底层的SQL语法。...
延迟加载是一种优化策略,它使得关联的对象在真正需要时才从数据库中加载,而不是在加载主对象时立即加载所有关联对象。这样可以避免不必要的数据检索,提高应用程序的运行效率。 **2. Hibernate中的延迟加载** 在...
高级Hibernate4开发技术:ORM思想,hibernate介绍,hibernate.cfg.xml配置,hbm.xml映射文件详解,主键生成策略使用,PO对象状态及状态的转换分析、一级缓存,Hibernate数据检索技术,Hibernate高级映射技术,...
高级Hibernate4开发技术:ORM思想,hibernate介绍,hibernate.cfg.xml配置,hbm.xml映射文件详解,主键生成策略使用,PO对象状态及状态的转换分析、一级缓存,Hibernate数据检索技术,Hibernate高级映射技术,...
### Hibernate的延迟检索在轻量级J2EE框架中的应用 #### 1. 引言 随着互联网技术的发展,Web应用程序的需求日益增加,对于高效、快速的开发模式也提出了更高的要求。轻量级J2EE框架(Struts+Spring+Hibernate)因...
6. **性能优化**:书中还涵盖了Hibernate的性能优化技巧,如第二级缓存的配置,批处理更新,延迟加载和懒加载策略,以及如何避免N+1查询问题。 7. **实战案例**:书中通常会包含丰富的实例,让读者在实践中掌握...
10. **Lazy Loading**:一种优化策略,允许延迟加载关联的对象,直到真正需要它们的时候才从数据库中获取。 使用这些核心JAR包,开发者可以轻松地实现Java应用程序的数据持久化,同时避免直接编写SQL语句,提高了...
Hibernate 是一个流行的 Java 持久层框架,它提供了多种检索数据的方式,包括导航对象图检索、OID 检索、HQL 检索、QBC 检索和本地 SQL 检索等。下面将详细介绍每种检索方式。 一、导航对象图检索 导航对象图检索...
6. **高级特性**:Hibernate还支持延迟加载、级联操作、集合映射、继承映射等高级功能。这些特性使得Hibernate能够处理更复杂的企业级应用场景。 7. **性能优化**:最后,书中会涉及如何调优Hibernate应用,包括...
### Hibernate数据检索(HQL)知识点详解 #### 一、简介 Hibernate 是一款开源的对象关系映射(ORM)框架,它允许开发人员将 Java 对象映射到数据库表中的记录,从而极大地简化了数据访问层的开发工作。本文档基于...
本教程将深入探讨"day36-hibernate检索和优化 02-Hibernate检索方式:简单查询及别名查询"的主题,通过源码分析和实际工具的应用,来提升数据库查询的效率。 首先,我们了解Hibernate的检索方式。在Hibernate中,...
《J2EE Hibernate-6.ppt》探讨了Hibernate在J2EE环境中的检索策略,主要涉及立即检索策略、延迟检索策略以及迫切左外连接检索策略。 1. **立即检索策略**: 立即检索策略是Hibernate默认的检索方式。在处理一对多...
【Hibernate检索策略】 Hibernate提供三种主要的检索策略:立即检索、延迟检索和迫切左外连接检索。 1. **立即检索**:这种策略将立即加载关联的对象,无论对象是持久化状态还是游离状态。优点是应用程序可以方便...
使用Hibernate ORM通常需要配置Hibernate配置文件(hibernate.cfg.xml),定义数据库连接参数、缓存策略等。实体类需使用注解标注属性与数据库字段的对应关系,然后通过SessionFactory创建Session,进而进行数据操作...
如果在关联级别设置了延迟加载策略,则首次执行此方法时,Hibernate会自动从数据库中加载这些关联的`Order`对象,否则将从缓存中获取。 ##### 2. OID检索方式 OID(Object Identifier)检索方式是指通过对象的唯一...
Hibernate的懒加载机制可以在需要时才加载关联的对象,避免了大量数据一次性加载导致的内存压力。但需注意防止“懒加载地狱”。 九、性能优化 包括但不限于:合理使用缓存,避免N+1查询问题,使用批处理更新,选择...