Hibernate使用批量抓取技巧
2016-11-01 23:56
197 查看
Hibernate批量抓取是延迟查询抓取的优化方案,你可以在两种Hibernate批量抓取方案之间进行选择:在类级别和集合级别。
类/实体级别的批量抓取很容易理解。假设你在运行时将需要面对下面的问题:你在一个Session中载入了25个Cat实例,每个Cat实例都拥有一个引用成员owner, 其指向Person,而Person类是代理,同时lazy="true"。
如果你必须遍历整个cats集合,对每个元素调用getOwner()方法,Hibernate将会默认的执行25次SELECT查询,得到其owner的代理对象。这时,你可以通过在映射文件的Person属性,显式声明batch-size,改变其行为:
<class name="Person" batch-size="10">...</class>
随之,Hibernate将只需要执行三次查询,分别为10、10、 5。
你也可以在集合级别定义批量抓取。例如,如果每个Person都拥有一个延迟载入的Cats集合,现在,Sesssion中载入了10个person对象,遍历person集合将会引起10次SELECT查询,每次查询都会调用getCats()方法。如果你在Person的映射定义部分,允许对cats批量抓取, 那么,Hibernate将可以预先抓取整个集合。
请看例子:
<class name="Person">
<set name="cats" batch-size="3">
...
</set>
</class>
如果整个的batch-size是3(笔误?),那么Hibernate将会分四次执行SELECT查询,按照3、3、3、1的大小分别载入数据。这里的每次载入的数据量还具体依赖于当前Session中未实例化集合的个数。
如果你的模型中有嵌套的树状结构,例如典型的帐单-原料结构(bill-of-materials pattern),集合的Hibernate批量抓取是非常有用的。(尽管在更多情况下对树进行读取时,嵌套集合(nested set)或原料路径(materialized path)(××) 是更好的解决方法。)
相关文章推荐
- [顶] Hibernate使用技巧收集
- Hibernate Oracle sequence的使用技巧
- codeigniter使用技巧批量插入数据实例方法分享
- Hibernate Oracle sequence的使用技巧
- Hibernate 抓取策略fetch-2 (批量抓取batch-size以及hibernate.jdbc.fetch_size、hibernate.jdbc.batch_size)
- SAS使用技巧- 动态抓取外部URL的网友内容
- Hibernate的使用技巧②
- Hibernate中HQL占位符的一点使用技巧
- vim使用技巧--批量加注释‘#’
- Hibernate学习---第十一节:Hibernate之数据抓取策略&批量抓取
- 使用XSLT抓取网站内容抽取网页数据的技巧
- hibernate之优化抓取(选择抓取策略之批量预抓取数据--实例2)
- hibernate之优化抓取(选择抓取策略之批量预抓取数据--实例1)
- codeigniter使用技巧批量插入数据实例方法分享
- Hibernate高级技巧:数据过滤器-使用XML和标注
- Hibernate Oracle sequence的使用技巧
- hibernate之优化抓取(选择抓取策略之批量预抓取数据)
- vim使用技巧--批量加注释‘#’
- Hibernate中HQL占位符的一点使用技巧
- Hibernate中HQL占位符的一点使用技巧