码迷,mamicode.com
首页 > 其他好文 > 详细

Mybatis 中延时加载

时间:2017-07-10 18:10:47      阅读:179      评论:0      收藏:0      [点我收藏+]

标签:开启   开始   soc   sso   lazyload   n+1   意义   发送   关联   

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 中延时加载

标签:开启   开始   soc   sso   lazyload   n+1   意义   发送   关联   

原文地址:http://www.cnblogs.com/zhaopengcheng/p/7146626.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!