码迷,mamicode.com
首页 > Web开发 > 详细

Hibernate检索策略

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

标签:hiberna   查询   持久层   select   batch   graph   query   hql   执行   

  我们在使用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检索策略

标签:hiberna   查询   持久层   select   batch   graph   query   hql   执行   

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!