MyBatis延迟加载实现步骤详解

 更新时间:2023年10月27日 11:12:55   作者:Rangers-sun  
这篇文章主要介绍了MyBatis延迟加载实现步骤详解,​ MyBatis中的延迟加载,也成为懒加载,是指在进行关联查询时,按照设置的延迟规则推迟对关联对象的查询,延迟加载可以有效的减少数据库的压力,需要的朋友可以参考下

延迟加载介绍

​ MyBatis中的延迟加载,也成为懒加载,是指在进行关联查询时,按照设置的延迟规则推迟对关联对象的查询。延迟加载可以有效的减少数据库的压力。延迟加载只是针对有延迟设置的关联对象的推迟查询,对于主主查询是直接进行执行SQL语句。

MyBatis关联查询加载时机

  • 直接加载:执行完主对象的查询后,马上执行对关联对象的查询语句
  • 侵入式延迟:执行完对主对象对查询后,不会执行对关联对象的查询,但当访问主对象的属性详情是,就会执行关联对象的查询
  • 深度延迟:只有当真正访问关联对象的详情时,才会执行查询语句

MyBatis延迟加载实现步骤

全局延迟

在MyBatis核心配置类中添加标签

<settings>
        <!-- 延迟加载总开关 -->
        <setting name="lazyLoadingEnabled" value="true"/>
        <!-- 侵入式延迟加载开关 -->
        <setting name="aggressiveLazyLoading" value="true"/>
</settings>

部分延迟

在关联查询collectionassociation标签上添加 fetchType 属性,lazy表示延迟加载,eager表示立即加载,指定属性后,将在映射中忽略全局配置参数 lazyLoadingEnabled,使用属性的

<resultMap id="userMap" type="com.rangers.entity.User">
    <result column="id" property="id"></result>
    <result column="name" property="name"></result>
    <result column="address" property="address"></result>

    <collection property="orderList" column="id" ofType="com.rangers.entity.Order"
                select="com.rangers.dao.OrderMapper.findOrderById" fetchType="lazy">
    </collection>
</resultMap>

<select id="findUserById" resultMap="userMap">
    select * from user where id=#{id}
</select>
<select id="findOrderById" parameterType="int" resultType="com.rangers.entity.Order">
    select * from `order` where uid=#{id}
</select>

注意

在延迟加载的测试过程中,有发现延迟加载未生效问题,就是在用户表查询后,订单信息也有值。

​ 经过探索发现,在debug模式下查看变量时,debug会另起一个线程,然后重新调用代码,debug弹出框显示用户信息时,会自动调用User类的hashCode()toString()方法。

解决一:不进行debug打断电,在查询后直接打印一段分割线,查看控制台信息

@org.junit.Test
public void testResult(){
    User user = userMapper.findUserById(1);
    System.out.println("------------------查询OrderList分割线------------------");
    System.out.println(user.getOrderList());
}

控制台显示

17:33:31,229 DEBUG findUserById:159 - ==>  Preparing: select * from user where id=? 
17:33:31,253 DEBUG findUserById:159 - ==> Parameters: 1(Integer)
17:33:31,283 DEBUG findUserById:159 - <==      Total: 1
------------------查询OrderList分割线------------------
17:33:31,284 DEBUG findOrderById:159 - ==>  Preparing: select * from `order` where uid=? 
17:33:31,284 DEBUG findOrderById:159 - ==> Parameters: 1(Integer)
17:33:31,290 DEBUG findOrderById:159 - <==      Total: 2
[Order{id=1, time=Wed Mar 10 17:22:30 CST 2021, total=1.11, uid=1, flag=0}, Order{id=2, time=Wed Mar 10 17:22:45 CST 2021, total=2.22, uid=1, flag=1}]

解决二:在MyBatis核心配置文件中添加setting标签,指定lazyLoadTriggerMethods属性为空

<setting name="lazyLoadTriggerMethods" value=""/>

lazyLoadTriggerMethods:指定对象的方法触发一次延迟加载。

默认值:equals() clone() hashCode() ) toString()

到此这篇关于MyBatis延迟加载实现步骤详解的文章就介绍到这了,更多相关MyBatis延迟加载实现内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 如何用注解的方式实现Mybatis插入数据时返回自增的主键Id

    如何用注解的方式实现Mybatis插入数据时返回自增的主键Id

    这篇文章主要介绍了如何用注解的方式实现Mybatis插入数据时返回自增的主键Id,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • java之CSV大批量数据入库的实现

    java之CSV大批量数据入库的实现

    本文主要介绍了java之CSV大批量数据入库的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-02-02
  • 解决spring中redistemplate不能用通配符keys查出相应Key的问题

    解决spring中redistemplate不能用通配符keys查出相应Key的问题

    这篇文章主要介绍了解决spring中redistemplate不能用通配符keys查出相应Key的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-11-11
  • Java中用内存映射处理大文件的实现代码

    Java中用内存映射处理大文件的实现代码

    下面小编就为大家带来一篇Java中用内存映射处理大文件的实现代码。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-06-06
  • Java 垃圾回收超详细讲解记忆集和卡表

    Java 垃圾回收超详细讲解记忆集和卡表

    卡表就是记忆集的一种具体实现,它定义了记忆集的记录精度、与堆内存的映射关系等。 关于卡表与记忆集的关系,不妨按照Java语言中HashMap与Map的关系来类比理解。记忆集是一种用于记录从非收集区域指向收集区域的指针集合的抽象数据结构
    2022-04-04
  • 扩展logback将日志输出到Kafka实例详解

    扩展logback将日志输出到Kafka实例详解

    logback是一个功能强大的Java日志框架,它是log4j的继任者,提供了丰富的功能和配置选项,本文将介绍如何通过扩展logback,将日志输出到Kafka实例,感兴趣的朋友一起看看吧
    2024-12-12
  • hadoop序列化实现案例代码

    hadoop序列化实现案例代码

    序列化想必大家都很熟悉了,对象在进行网络传输过程中,需要序列化之后才能传输到客户端,或者客户端的数据序列化之后送达到服务端,本文将为大家介绍Hadoop如何实现序列化,需要的可以参考一下
    2022-01-01
  • Java创建数组、赋值的四种方式详解(声明+创建+初始化 )

    Java创建数组、赋值的四种方式详解(声明+创建+初始化 )

    数组是一种数据结构,用来存储同一类型值的集合一旦创建了数组,就不能再改变它的长度,下面这篇文章主要给大家介绍了关于Java创建数组、赋值的四种方式(声明+创建+初始化 )的相关资料,需要的朋友可以参考下
    2024-04-04
  • 举例讲解Java中final关键字的用法

    举例讲解Java中final关键字的用法

    Java中的final关键字可以被用来修饰变量、方法和类等,意味着终结、不可改变,下面我们就来举例讲解Java中final关键字的用法:
    2016-06-06
  • SpringBoot使用Redis缓存的实现方法

    SpringBoot使用Redis缓存的实现方法

    这篇文章主要介绍了SpringBoot使用Redis缓存的实现方法,需要的朋友可以参考下
    2018-02-02

最新评论