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