1. 延迟加载
什么是延迟加载?延迟加载 的反义词就是 立即加载,
立即加载 是指在取得“省”对象时(此处的数据库表:省包含市),省中所有的“市”对象都已经提取到内存中,因此其非常耗费 CPU 和内存资源。有时只需要省信息,而并不需要市信息,但立即加载还是把市信息也一同提取出来,这样的情况下就要使用延迟加载了。
延迟加载 就是在使用到市对象时,再把其加载到内存中来,如果不使用市对象,就不加载到内存中,这就是延迟加载特性。
2. 默认立即加载策略
MyBatis 默认的行为就是 立即加载。
当在程序中 调用到 List 中的 Userinfo 对象时,就采取了立即加载策略,立即将 Userinfo 对应的对象加载到内存中。
3. 使用全局延迟加载策略与两种加载方式
在配置文件中使用如下配置代码开始延迟加载:
<settings>
<setting name="logImpl" value="LOG4J" />
<setting name="lazyLoadingEnable" value="true" />
</settings>
但延迟加载具体的实现方式分为两种。
(1)获得子表时再进行加载。
(2)打印主表信息时加载子表。
这两种延迟加载的方式可以使用以下配置来进行切换,默认情况时第一种:
<settings>
<setting name="aggressiveLazyLoading" value="" />
</settings>
更改配置文件。代码如下:
<settings>
<setting name="logImpl" value="LOG4J" />
<setting name="lazyLoadingEnable" value="true" />
</settings>
4. 使用 fetchType 属性设置局部加载策略
使用配置选项 lazyLoadingEnabled 和 aggressiveLazyLoading 设置的是全局加载行为。如果想针对某一个映射来决定是延迟加载还是立即加载,那么可以在