首页 > Web开发 > 详细

Hibernate检索策略

时间:2017-02-19 14:11:53      阅读:223      评论:0      收藏:0      [点我收藏+]

  我们在使用Hibernate作为持久层框架,从数据库中获取数据的时候Hibernate提供了集中获取数据的策略,来提升性能。

 既然是提升性能,那就可以分两种类型考虑,一种是什么时候获取数据,另一种就是怎么获取数据。

   Hibernate中有以下集中作用域来定义抓取策略。

  static:静态的定义是在mappding中定义的。

    |-SELECT:另外发送一条 SELECT 语句抓取当前对象的关联实体或集合。除非你显式的指定 lazy="false" 禁止 延迟抓取(lazy fetching),否则只有当你真正访问关联关系的时候,才会执行第二条 select 语句

    |-JOIN:通过外连接的方式立刻抓取

    |-BATCH:对查询抓取的优化方案,通过指定一个主键或外键列表,Hibernate 使用单条 SELECT 语句获取一批对象实例或集合。

    |-SUBSELECT:另外发送一条 SELECT 语句抓取在前面查询到(或者抓取到)的所有实体对象的关联集合。除非你显式的指定 lazy="false" 禁止延迟抓取(lazyfetching),否则只有当你真正访问关联关系的时候,才会执行第二条 select 语句。

  dynamic:有下面几种方式来定义

    |-fetch profiles:在mapping中定义的,但是可以在Session中来开关

    |-HQL/JPQL:在Hibernate或者JPA Criteria查询中通过query来指定

    |-entity graphs:在Hibernate4.2中引入的一个可选功能。

Hibernate检索策略

原文:http://www.cnblogs.com/zerotomax/p/6415517.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!