码迷,mamicode.com
首页 > 其他好文 > 详细

12、mybatis懒加载的设置

时间:2020-02-23 14:57:02      阅读:156      评论:0      收藏:0      [点我收藏+]

标签:lse   als   lazy   sql   属性   成员   mamicode   table   控制   

MyBatis的Lazy Loading可以实现延迟查询Bean里的嵌套成员类,控制lazy loading的<settings>属性有

lazyLoadingEnabled: lazy loading开关

aggressiveLazyLoading: 侵略性 lazy loading 开关

 

设置项 描述 允许值 默认值
lazyLoadingEnabled 全局性设置懒加载。如果设为‘false’,则所有相关联的都会被初始化加载。 true | false 3.4.1后为false
aggressiveLazyLoading 当设置为‘true’的时候,懒加载的对象可能被任何懒属性全部加载。否则,每个属性都按需加载。 true | false 3.4.1后为true

 

延迟加载

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

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

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

延迟加载分为三种类型:

1.直接加载

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

2.侵入式加载

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

3.深度延迟加载

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

 

看一下几个例子

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

技术图片

 

  2.侵入式延迟加载

 

技术图片

技术图片

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

技术图片

 

   3.深度延迟加载

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

技术图片

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

 

技术图片

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

 

 

 

技术图片

我现在用的mybatis3.5.3的默认值为:
<settings>
<setting name="lazyLoadingEnabled" value="false"/>
<setting name="aggressiveLazyLoading" value="true"/> <!--现在的状态为直接加载-->(3.4.1版本之后的直接加载设置)
</settings>

所以改为深度延迟加载即
<settings>
<setting name="lazyLoadingEnabled" value="true"/>
<setting name="aggressiveLazyLoading" value="false"/> <!--现在的状态为直接加载-->(3.4.1版本之后的直接加载设置)
</settings>

建议修改懒加载时这两个设置项同时修改

12、mybatis懒加载的设置

标签:lse   als   lazy   sql   属性   成员   mamicode   table   控制   

原文地址:https://www.cnblogs.com/lyh233/p/12349662.html

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