一、概念
MyBatis中的延迟加载,也称为懒加载,是指在进行表的关联查询时,按照设置延迟规则推迟对关联对象的select查询。例如在进行一对多查询的时候,只查询出一方,当程序中需要多方的数据时,mybatis再发出sql语句进行查询,这样子延迟加载就可以的减少数据库压力。MyBatis 的延迟加载只是对关联对象的查询有迟延设置,对于主加载对象都是直接执行查询语句的。
二、原理
MyBatis实现延迟加载的方式是使用代理对象,在访问未加载的数据时触发代理对象的方法,从而进行数据的加载。
三、延迟加载支持的对象
Mybatis 仅支持 association 关联对象和 collection 关联集合对象的延迟加载,association 指的就是一对一,collection 指的就是一对多查询。
四、 配置延迟加载
1.配置全局延迟加载
<!-- 在Mybatis的核⼼配置⽂件中可以使⽤setting标签修改全局的加载策略-->
<settings>
<!-- 打开延迟加载的开关 -->
<setting name="lazyLoadingEnabled" value="true"/>
<!--不是必要的标签 false 深入式延迟加载 true 侵

本文介绍MyBatis中的延迟加载(懒加载)概念及其配置方法。通过使用代理对象,在访问未加载的数据时触发数据加载,以减少数据库压力。文章详细解释了全局与局部配置的区别,并提供了具体的XML配置示例。
337

被折叠的 条评论
为什么被折叠?



