Mybatis 的延迟加载?及其原理?

概念

MyBatis中的延迟加载,也称为懒加载,是指在进行表的关联查询时,按照设置延迟规则推迟对关联对象的select查询。例如在进行一对多查询的时候,只查询出一方,当程序中需要多方的数据时,mybatis再发出sql语句进行查询,这样子延迟加载就可以的减少数据库压力。MyBatis 的延迟加载只是对关联对象的查询有迟延设置,对于主加载对象都是直接执行查询语句的。

延迟加载

Mybatis 仅支持 association 关联对象和 collection 关联集合对象的延迟加
载,association 指的就是一对一,collection 指的就是一对多查询。

association 一对一

collection 一对多

怎么开启延迟加载


	<settings>
		
		<setting name="lazyLoadingEnabled" value="true"/>
		
	 	<setting name="aggressiveLazyLoading" value="false"/>
	settings>

侵入式延迟加载和深入式延迟加载的区别

class 与 student 之间是一对多关系,我们在加载时,可以先加载 class 数据,当需要使用到 student 数据时,我们再加载 student 的相关数据。

  1. 侵入式延迟加载
    侵入式延迟加载指的是只要主表的任一属性加载,就会触发延迟加载,比如:class 的 name 被加载,student 信息就会被触发加载。
  2. 深度延迟加载
    深度延迟加载指的是只有关联的从表信息被加载,延迟加载才会被触发。
    通常,我们在实战中更倾向使用深度延迟加载。

原理

使用 CGLIB 创建目标对象的代理对象,当调用目标方法时,进入拦截器方法,比如调用 a.getB().getName(),拦截器 invoke()方法发现 a.getB()是null 值,那么就会单独发送事先保存好的查询关联 B 对象的 sql,把 B 查询上来,然后调用 a.setB(b),于是 a 的对象 b 属性就有值了,接着完成 a.getB().getName()方法的调用。这就是延迟加载的基本原理。

你可能感兴趣的:(mybatis,java,开发语言)