首页 > 代码库 > hibernate 延迟加载和抓取策略

hibernate 延迟加载和抓取策略

一、延迟加载

1.简单查询get,load 针对对象本身延迟或即时

当使用load方法来得到一个对象时,此时hibernate会使用延迟加载的机制来加载这个对象,即:当我们使用session.load()方法来加载一个对象时,此时并不会发出sql语句,当前得到的这个对象其实是一个代理对象,这个代理对象只保存了实体对象的id值,只有当我们要使用这个对象,得到其它属性时,这个时候才会发出sql语句,从数据库中去查询我们的对象。

相对于load的延迟加载方式,get就直接的多,当我们使用session.get()方法来得到一个对象时,不管我们使不使用这个对象,此时都会发出sql语句去从数据库中查询出来

2.相关对象的延迟或即时,通过配置中lazy="true/false/proxy" 

在hibernate中可以通过一些采用延时加载策略封装的方法实现延时加载的功能,我们不仅也可以用load()方法进行延时加载,还可以在映射文件中的<property>元素中的lazy属性实现该功能。如下图所示

技术分享

 注意:当使用get加载对象时,不一定就是立即查询,要根据你查询的内容和配置文件中的信息而定。(当然get加载语句中的对象.class一定是立即执行的,刚才所说的意思是,当通过外键查询其他表时,那么那些查询语句就不一定是立即执行)

例如:技术分享

lazy:默认是true(延迟加载),当设置成false时,就会立即执行查询的语句。

lazy还有一个属性值是proxy:(和select差不多,自动根据实际情况来,用谁查谁)

二、抓取策略

连 接抓取(Join fetching)

    连接抓取, 使用连接抓取可以将原本需要查询两次(或多次)表的多次查询 整合到只需要一次查询即可完成, 举个例子, 当查询多个表的时候需要发送至少两条 SQL 语句, 而如果使用 join 查询的话, 其会根据需要查询的将 表与表连接起来进行查询,仅仅一条 SQL 语句就可以将需要的数据全部查询回来;

 技术分享

查询抓取(Select fetching)

    查询抓取, 这种策略是在集合抓取的时候的默认策略, 即如果集合需要初始化, 那么会重新发出一条 SQL 语句进行查询; 这是集合默认的抓取策略, 也就是我们常会出现N+1次查询的查询策略;

技术分享

子查询抓取(Subselect fetching) 

子查询抓取, 另外发送一条SELECT 语句抓取在前面查询到(或者抓取到)的所有实体对象的关联集合

技术分享

 

hibernate 延迟加载和抓取策略