我们在使用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中引入的一个可选功能。