Mybatis本身给出解决方案,就是延迟加载。
延迟加载
延迟加载会解决上述的N+1问题,也就是在N+1个级联表的情况下,只加载需求的数据库表数据。这是互联网发展的需求,性能提升的途径。
如何配置Mybatis完成延迟加载
全局配置:
-
lazyLoadingEnabled true/false
-
aggressiveLazyLoading true/false
lazyLoadingEnabled:延迟加载的全局开关,当开启时,所有关联都会延迟加载。在特定的关联中,
使用fetchType属性覆盖该内容的功能。fetchType将在后面介绍。
aggressiveLazyLoading:是层级延迟加载开关,什么意思呢?就是处于同一个层级的关联表会同
时延迟加载,或者同时被加载。
配置:
在Mybatis的全局配置中的setting标签中加入设置
全局配置的缺点
上面的配置属于全局配置,会出现一个问题,同一个层级的级联表也存在需求性的差异,同一级的某个数据库表的数据或许不是我们经常使用的,那么上述的配置也会影响系统的性能。