zoukankan      html  css  js  c++  java
  • (转)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 语句抓取在前面查询到(或者抓取到)的所有实体对象的关联集合

    转自:http://www.cnblogs.com/hq233/p/6525475.html

  • 相关阅读:
    并查集
    强联通分量,缩点
    最短路径
    最小生成树
    拓扑排序
    图的遍历
    图论基础知识
    数据库四种隔离级别
    MySQL 索引 乐观锁 悲观锁
    MYSQL+正则
  • 原文地址:https://www.cnblogs.com/jonsnow/p/6535754.html
Copyright © 2011-2022 走看看