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延迟加载实现内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • SpringCloud Zuul的使用简介

    SpringCloud Zuul的使用简介

    这篇文章主要介绍了SpringCloud Zuul的使用简介,帮助大家更好的理解和学习使用Spring Cloud,感兴趣的朋友可以了解下
    2021-04-04
  • SpringBoot JWT实现token登录刷新功能

    SpringBoot JWT实现token登录刷新功能

    JWT本身是无状态的,这点有别于传统的session,不在服务端存储凭证。这种特性使其在分布式场景,更便于扩展使用。接下来通过本文给大家分享SpringBoot JWT实现token登录刷新功能,感兴趣的朋友一起看看吧
    2021-09-09
  • Java排序算法中的插入排序算法实现

    Java排序算法中的插入排序算法实现

    这篇文章主要介绍了Java排序算法中的插入排序算法实现,插入排序是将数组中的数据分为两个区间,已排序区间和未排序区间,其中已排序区间初始只有一个元素,就是数组的第一个元素,需要的朋友可以参考下
    2023-12-12
  • 浅谈Java并发编程中的线程

    浅谈Java并发编程中的线程

    这篇文章主要介绍了浅谈Java并发编程中的线程,操作系统运行一个程序,就会创建一个进程,在一个进程里可以创建多个线程,因此线程也叫做轻量级进程,需要的朋友可以参考下
    2023-08-08
  • java list去重操作实现方式

    java list去重操作实现方式

    本文主要介绍了java list 去重的方法,其中有带类型写法和不带类型写法,并举例测试,具有一定参考借鉴价值,希望能对有需要的小伙伴有所帮助
    2016-07-07
  • Java实现解析并生成xml原理实例详解

    Java实现解析并生成xml原理实例详解

    这篇文章主要介绍了Java实现解析并生成xml原理实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-06-06
  • java.mail实现发送邮件

    java.mail实现发送邮件

    这篇文章主要为大家详细介绍了java.mail实现发送邮件,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-02-02
  • Java代码注释规范详解

    Java代码注释规范详解

    代码附有注释对程序开发者来说非常重要,随着技术的发展,在项目开发过程中,必须要求程序员写好代码注释,这样有利于代码后续的编写和使用。下面给大家分享java代码注释的规范,需要的朋友参考下
    2016-02-02
  • Java编程计算兔子生兔子的问题

    Java编程计算兔子生兔子的问题

    古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第四个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少
    2017-02-02
  • 浅谈Spring框架中@Autowired和@Resource的区别

    浅谈Spring框架中@Autowired和@Resource的区别

    最近review别人代码的时候,看到了一些@Autowired不一样的用法,觉得有些意思,下面这篇文章主要给大家介绍了关于Spring框架中@Autowired和@Resource区别的相关资料,需要的朋友可以参考下
    2022-10-10

最新评论