MyBatis中的延迟加载,也称为懒加载,是指进行关联查询时,按需执行子查询。数据库
当程序须要获取|使用关联对象时,mybatis再执行子查询,这样能够减轻数据库的压力。mybatis
懒加载的适用场景:app
当前业务只使用主加载对象的其余属性,或者暂时只使用主加载对象的其余属性,长时间之后才使用主加载对象的关联对象属性。fetch
懒加载只对关联查询起做用(一对1、一对多、多对多),且只对嵌套查询方式起做用,由于嵌套结果、扩展类的方式都是一次查询所需数据,不存在子查询,也就不存在延迟加载的状况。spa
MyBatis的延迟加载只是延迟执行子查询,对于主加载对象的查询都是直接执行的。
code
一共有三种:对象
懒加载一共有2种方式,按照懒的程度,分为侵入式延迟、深度延迟。blog
可在全局配置文件中进行配置,也能够在映射文件中进行配置。ci
默认就是直接加载,什么都不用配置,固然也能够显式配置:get
<settings> <setting name="lazyLoadingEnabled" value="false"/> </settings>
<settings>
<!-- 使用懒加载 -->
<setting name="lazyLoadingEnabled" value="true"/>
<!-- 使用侵入式延迟的懒加载 -->
<setting name="aggressiveLazyLoading" value="true"/>
</settings>
aggressive 咄咄逼人的、激进的、主动模式的、喜爱侵入的,一有机会就加载,故名侵入式延迟。
缺省aggressiveLazyLoading时,默认为true——侵入式延迟。(听说旧版本的默认值是false——深度延迟,我未去验证。)
<settings>
<!-- 使用懒加载 -->
<setting name="lazyLoadingEnabled" value="true"/>
<!-- 使用深度延迟的懒加载 -->
<setting name="aggressiveLazyLoading" value="false"/>
</settings>
<collection property="goodsList" select="com.chy.mapper.GoodsMapper.queryGoodsByGoodsId" column="no" ofType="goods" fetchType="lazy"/>
有2个可选的值:
此种方式不能指定为侵入式延迟。
在全局配置文件中进行的配置是配置全部的,在映射文件中的配置是配置单个的。
若是在mybatis全局配置文件中显式配置了懒加载,又在映射文件中配置了懒加载,冲突时以全局配置文件中的配置为准。