Python 官方文档:入门教程 => 点击学习
目录MaBatis加载策略1.什么是延迟加载1.2实现1.2.1局部延迟加载1.2.2设置触发延迟加载的方法1.2.3全局延迟加载MaBatis加载策略 1.什么是延迟加载 myba
mybatis中一对一,一对多,多对多关系的配置及实现,可以实现对象的关联查询。实际开发过程中很多时候我们并不需要总是在加载用户信息时就一定要加载他的订单信息。此时就是我们所说的延迟加载。
例如:
问题1:在一对多中,当我们有一个用户,它有个100个订单在查询用户的时候,要不要把关联的订单查出来?
**问题2:**在查询订单的时候,要不要把关联的用户查出来?
就是在需要用到数据时才进行加载,不需要用到数据时就不加载数据。延迟加载也称懒加载。
注意:
延迟加载是基于嵌套查询来实现的
先从单表查询,需要时再从关联表去关联查询,大大提高数据库性能,因为查询单表要比关联查询多张表
速度要快。
因为只有当需要用到数据时,才会进行数据库查询,这样在大批量数据查询时,因为查询工作也要消耗时
间,所以可能造成用户等待时间变长,造成用户体验下降。
一对多,多对多:通常情况下采用延迟加载
一对一(多对一):通常情况下采用立即加载
在association和collection标签中都有一个fetchType属性,通过修改它的值,可以修改局部的加载策略。
xml配置文件:
<!--
嵌套查询:查询用户所对应的订单
-->
<resultMap id="getUserInfoWithNested" type="user">
<id property="id" column="id"></id>
<result property="username" column="username"></result>
<result property="birthday" column="birthday"></result>
<result property="sex" column="sex"></result>
<result property="address" column="address"></result>
<!--
fetchType="lazy" 懒加载策略
fetchType="eager" 立即加载策略
-->
<collection property="ordersList" ofType="com.laGou.domain.Orders" select="com.lagou.mapper.OrdersMapper.findUserAllOrder" column="id" fetchType="lazy" ></collection>
</resultMap>
<select id="findUserOrder2" resultMap="getUserInfoWithNested">
select * from user
</select>
<!-- 设置延迟加载策略-->
<settings>
<!-- 所有方法都会延迟加载-->
<setting name="lazyLoadTriggerMethods" value="toString()"/>
</settings>
<settings>
<!-- 所有方法都会延迟加载-->
<setting name="lazyLoadTriggerMethods" value="toString()"/>
<!--开启全局延迟加载功能-->
<setting name="lazyLoadingEnabled" value="true"/>
</settings>
注意:局部的加载策略优先级高于全局的加载策略。
订单没有被查询出来:
到此这篇关于Mybatis加载策略的文章就介绍到这了,更多相关Mybatis加载策略内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: Mybatis加载策略的实现方法
本文链接: https://lsjlt.com/news/140394.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0