1. 延迟加载
- 开发过程中很多时候我们并不需要总是在加载用户信息时就一定要加载他的订单
信息。此时就是我们所说的延迟加载。 - 就是在需要用到数据时才进行加载,不需要用到数据时就不加载数据。延迟加载也称懒加载。
优点:
先从单表查询,需要时再从关联表去关联查询,大大提高数据库性能,因为查询单表要比关联查询多张表
速度要快。
* 缺点:
因为只有当需要用到数据时,才会进行数据库查询,这样在大批量数据查询时,因为查询工作也要消耗时
间,所以可能造成用户等待时间变长,造成用户体验下降。
- 在多表中:
一对多,多对多:通常情况下采用延迟加载
一对一(多对一):通常情况下采用立即加载 - 注意:
延迟加载是基于嵌套查询来实现的
1.1 局部延迟加载
- 在association和collection标签中都有一个fetchType属性,通过修改它的值,可以修改局部的加载策
略。
fetchType="lazy" 懒加载策略
fetchType="eager" 立即加载策略
注意事项:
- 在配置了延迟加载策略后,发现即使没有调用关联对象的任何方法,但是在调用当前对象的
equals、clone、hashCode、toString方法时也会触发关联对象的查询。
在核心配置文件中使用lazyLoadTriggerMethods配置项覆盖掉上面四个方法。
<settings>
<!--所有方法都会延迟加载-->
<setting name="lazyLoadTriggerMethods" value="toString()"/>
</settings>
1.2 全局延迟加载
- 在Mybatis的核心配置文件中可以使用setting标签修改全局的加载策略。
<settings>
<!--开启全局延迟加载功能-->
<setting name="lazyLoadingEnabled" value="true"/>
</settings>
注意
- 局部的加载策略优先级高于全局的加载策略。
注解延迟加载
- 一对一或一对多 ,在注解配置中都有fetchType的属性
* fetchType = FetchType.LAZY 表示懒加载
* fetchType = FetchType.EAGER 表示立即加载
* fetchType = FetchType.DEFAULT 表示使用全局配置