MyBatis 延迟加载的三种加载方式深入,你get了吗?

Posted 就让文谦先行

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MyBatis 延迟加载的三种加载方式深入,你get了吗?相关的知识,希望对你有一定的参考价值。

延迟加载

  延迟加载对主对象都是直接加载,只有对关联对象是延迟加载。

  延迟加载可以减轻数据库的压力,

  延迟加载不可是一条SQL查询多表信息,这样构不成延迟加载,会形成直接加载。

  延迟加载分为三种类型:

1.直接加载

执行完主对象之后,直接执行关联对象。

2.侵入式加载

在执行主对象详情的时候,执行关联对象。

3.深度延迟加载

执行完主对象或主对象详情不会执行关联对象,只有用到关联对象数据的时候才走深度延迟加载。

  延迟加载默认情况下是关闭状态(false) 延迟加载下的侵入式加载默认情况下是开启状态(true)  在这种情况下延迟加载不生效, 比如说延迟加载是一个大的水龙头总闸,如果总闸没开,那么总闸里面的小的闸肯定没有水。如果想要使用延迟加载必须写成true

  现在知道延迟加载的状态,那他是在哪里设置开启关闭状态的呢? 答案是在大配置文件中设置延迟加载的状态

看一下几个例子

1.默认情况的延迟加载  (这是在MyBatis3.4.1版本之前的默认情况) :(aggressiveLazyLoading)侵入式延迟加载为true, 在3.4.1之后的版本(aggressiveLazyLoading)侵入式延迟加载默认值为false

 

  2.侵入式延迟加载

 

现在看一下访问主属性的侵入式延迟加载的状态如何

 

   3.深度延迟加载

深度延迟加载 大配置中的设置

只访问主对象的属性,深度延迟加载的状态为:

 

现在我们看一下访问关联对象的属性,深度延迟加载的状态为:

 

在大配置文件设置延迟加载是使用的是setting节点,与其他节点位置顺序不要乱。

大配置中的延迟加载代码:

<settings>
<setting name="lazyLoadingEnabled" value="true"/>
<setting name="aggressiveLazyLoading" value="false"/> <!--现在的状态为深度延迟加载-->
</settings>
<settings>
<setting name="lazyLoadingEnabled" value="true"/>
<setting name="aggressiveLazyLoading" value="true"/> <!--现在的状态为侵入式延迟加载-->
</settings>

<settings>
<setting name="lazyLoadingEnabled" value="false"/>
<setting name="aggressiveLazyLoading" value="false"/> <!--现在的状态为直接加载-->(3.4.1版本之后的直接加载设置)
</settings>

<settings>
<setting name="lazyLoadingEnabled" value="false"/>
<setting name="aggressiveLazyLoading" value="true"/> <!--现在的状态为直接加载-->(3.4.1版本之前的直接加载设置)
</settings>
 

 

以上是关于MyBatis 延迟加载的三种加载方式深入,你get了吗?的主要内容,如果未能解决你的问题,请参考以下文章

类加载器盲区整理

EF的三种数据加载方式

MyBatis_延迟加载

Mybatis 是否支持延迟加载?如果支持,它的实现原理是 什么?

mybatis_延迟加载

11.延迟加载