文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Mybatis加载策略的实现方法

2024-04-02 19:55

关注

MaBatis加载策略

1.什么是延迟加载

Mybatis中一对一,一对多,多对多关系的配置及实现,可以实现对象的关联查询。实际开发过程中很多时候我们并不需要总是在加载用户信息时就一定要加载他的订单信息。此时就是我们所说的延迟加载。

例如:

问题1:在一对多中,当我们有一个用户,它有个100个订单在查询用户的时候,要不要把关联的订单查出来?

**问题2:**在查询订单的时候,要不要把关联的用户查出来?

就是在需要用到数据时才进行加载,不需要用到数据时就不加载数据。延迟加载也称懒加载。

注意:

延迟加载是基于嵌套查询来实现的

先从单表查询,需要时再从关联表去关联查询,大大提高数据库性能,因为查询单表要比关联查询多张表
速度要快。

因为只有当需要用到数据时,才会进行数据库查询,这样在大批量数据查询时,因为查询工作也要消耗时
间,所以可能造成用户等待时间变长,造成用户体验下降。

一对多,多对多:通常情况下采用延迟加载
一对一(多对一):通常情况下采用立即加载

1.2实现

1.2.1 局部延迟加载

在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>

1.2.2 设置触发延迟加载的方法

<!--    设置延迟加载策略-->
    <settings>
		<!--        所有方法都会延迟加载-->
        <setting name="lazyLoadTriggerMethods" value="toString()"/>
    </settings>

1.2.3全局延迟加载

<settings>
<!--        所有方法都会延迟加载-->
        <setting name="lazyLoadTriggerMethods" value="toString()"/>
        <!--开启全局延迟加载功能-->
        <setting name="lazyLoadingEnabled" value="true"/>
    </settings>

注意:局部的加载策略优先级高于全局的加载策略。

订单没有被查询出来:

image-20220224135802752

到此这篇关于Mybatis加载策略的文章就介绍到这了,更多相关Mybatis加载策略内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯