博客
关于我
MyBatis(十):MyBatis懒加载 延迟加载详解
阅读量:762 次
发布时间:2019-03-23

本文共 1803 字,大约阅读时间需要 6 分钟。

  1. 延迟加载介绍

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

  2. MyBatis关联查询加载时机

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

    • 全局延迟

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

    • 部分延迟

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

  4. 注意点

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

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

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

    @org.junit.Testpublic 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属性为空

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

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

转载地址:http://cwmzk.baihongyu.com/

你可能感兴趣的文章
Member var and Static var.
查看>>
memcached高速缓存学习笔记001---memcached介绍和安装以及基本使用
查看>>
memcached高速缓存学习笔记003---利用JAVA程序操作memcached crud操作
查看>>
Memcached:Node.js 高性能缓存解决方案
查看>>
memcache、redis原理对比
查看>>
memset初始化高维数组为-1/0
查看>>
Metasploit CGI网关接口渗透测试实战
查看>>
Metasploit Web服务器渗透测试实战
查看>>
MFC模态对话框和非模态对话框
查看>>
Moment.js常见用法总结
查看>>
MongoDB出现Error parsing command line: unrecognised option ‘--fork‘ 的解决方法
查看>>
mxGraph改变图形大小重置overlay位置
查看>>
MongoDB可视化客户端管理工具之NoSQLbooster4mongo
查看>>
Mongodb学习总结(1)——常用NoSql数据库比较
查看>>
MongoDB学习笔记(8)--索引及优化索引
查看>>
mongodb定时备份数据库
查看>>
mppt算法详解-ChatGPT4o作答
查看>>
mpvue的使用(一)必要的开发环境
查看>>
MQ 重复消费如何解决?
查看>>
mqtt broker服务端
查看>>