Mybatis 中延时加载
Posted pclover11
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mybatis 中延时加载相关的知识,希望对你有一定的参考价值。
1 为了处理N+1 问题,Mybatis 引入了延时加载功能,意义是一开始并不取出关联数据,只有当使用时,才发送sql语句去取。
mybatis中两个全局设置 lazyLoadingEnabled 和 aggressiveLazyLoading 是否开启延迟加载功能。
mybatis 中的默认情况下是及时加载的,一旦关联比较多,会造成性能问题。
1.1)如果设置 lazyLoadingEnabled = true,默认情况下mybatis 是按层级延时加载的。
1.2)如果在设置了1.1 后,使用 aggressiveLazyLoading 可以按需加载。
1.2.1) aggressiveLazyLoading = true,mybatis 是按层级延时加载
1.2.2) aggressiveLazyLoading = false,mybatis 按需求加载。
1.2 有时全局配置不是那么的适合自己需求,mybatis 提供了局部延时加载功能。
在 collection 或 association 元素上加入属性值 fetchType 就可以了,他有两个取值 eager 和 lazy。
以上是关于Mybatis 中延时加载的主要内容,如果未能解决你的问题,请参考以下文章
java:Mybatis框架3(二级缓存,延时和积极加载,SSI(Ibatis)集成,SSM集成)