Hibernate使用批量抓取技巧

开发 后端
Hibernate可以充分有效的使用Hibernate批量抓取,也就是说,如果仅一个访问代理(或集合),那么Hibernate将不载入其他未实例化的代理。

大家都知道Hibernate可以充分有效的使用批量抓取,也就是说,如果仅一个访问代理(或集合),那么Hibernate将不载入其他未实例化的代理。

Hibernate批量抓取是延迟查询抓取的优化方案,你可以在两种Hibernate批量抓取方案之间进行选择:在类级别和集合级别。

类/实体级别的批量抓取很容易理解。假设你在运行时将需要面对下面的问题:你在一个Session中载入了25个Cat实例,每个Cat实例都拥有一个引用成员owner, 其指向Person,而Person类是代理,同时lazy="true"。

如果你必须遍历整个cats集合,对每个元素调用getOwner()方法,Hibernate将会默认的执行25次SELECT查询,得到其owner的代理对象。这时,你可以通过在映射文件的Person属性,显式声明batch-size,改变其行为:

  1. <class name="Person" batch-size="10">...</class> 

随之,Hibernate将只需要执行三次查询,分别为10、10、 5。

你也可以在集合级别定义批量抓取。例如,如果每个Person都拥有一个延迟载入的Cats集合,现在,Sesssion中载入了10个person对象,遍历person集合将会引起10次SELECT查询,每次查询都会调用getCats()方法。如果你在Person的映射定义部分,允许对cats批量抓取, 那么,Hibernate将可以预先抓取整个集合。

请看例子:

  1. <class name="Person"> 
  2.     <set name="cats" batch-size="3"> 
  3.         ...  
  4.     </set> 
  5. </class> 

如果整个的batch-size是3(笔误?),那么Hibernate将会分四次执行SELECT查询,按照3、3、3、1的大小分别载入数据。这里的每次载入的数据量还具体依赖于当前Session中未实例化集合的个数。

如果你的模型中有嵌套的树状结构,例如典型的帐单-原料结构(bill-of-materials pattern),集合的Hibernate批量抓取是非常有用的。(尽管在更多情况下对树进行读取时,嵌套集合(nested set)或原料路径(materialized path)(××) 是更好的解决方法。)

【编辑推荐】

  1. 简述Hibernate中加载并存储对象
  2. Hibernate传播性持久化攻略
  3. 深入了解Hibernate自动状态检测
  4. 教你如何在Hibernate中实例化集合和代理
  5. Hinerbate单端关联代理颇析
责任编辑:仲衡 来源: TechTarget
相关推荐

2009-09-24 14:28:23

Hibernate抓取

2009-09-24 09:25:10

Hibernate批量

2009-09-24 09:45:23

Hibernate批量

2009-09-25 11:34:54

Hibernate处理Hibernate批量

2009-09-27 14:33:01

Hibernate批量

2009-06-16 16:39:49

Hibernate性能

2009-06-03 10:02:53

Hibernate批量删除

2009-06-12 15:09:01

Hibernate优化

2009-06-18 11:12:42

Hibernate S优化

2009-12-02 15:50:41

PHP抓取网页内容

2010-02-23 09:33:39

Hibernate批量Hibernate批量

2009-06-12 14:44:30

Hibernate A批量更新

2019-07-24 16:00:37

Python代码高清图片

2009-06-16 16:27:22

Hibernate优化

2009-06-16 16:10:59

Hibernate性能

2009-09-28 13:43:28

使用Hibernate

2009-09-23 10:14:10

Hibernate使用

2009-09-25 13:55:05

Hibernate使用

2009-09-29 16:48:42

Hibernate J

2009-09-23 10:28:49

使用Hibernate
点赞
收藏

51CTO技术栈公众号