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

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

MyBatis延迟加载详解

延迟加载(Lazy Loading)是MyBatis中一个非常实用的特性,旨在通过推迟对关联对象的查询,减少数据库的负载。以下将从基础到应用详细探讨MyBatis的延迟加载机制。

延迟加载的概念

延迟加载的核心思想是在主查询完成后,根据预设规则推迟对关联对象的查询。这种机制特别适用于关联多个表的情景,能够显著减少数据库的查询压力。需要注意的是,延迟加载仅适用于有明确延迟设置的关联对象,而主查询仍旧会直接执行。

延迟加载的时机

MyBatis提供了三种延迟加载的策略,可以根据具体需求灵活选择:

  • 直接加载:在主对象查询完成后,立即执行关联对象的查询。

  • 侵入式延迟:仅在访问关联对象的属性详情时,才会执行关联查询。这种方式能够更好地控制查询的执行时间。

  • 深度延迟:只有在真正访问关联对象详情时,才会触发关联查询。

  • 延迟加载的实现

    要在MyBatis中实现延迟加载,可以按照以下步骤操作:

  • 全局延迟设置

    在MyBatis的核心配置文件中启用延迟加载功能:

  • 部分延迟设置

    在关联查询的collectionassociation标签中,通过fetchType属性指定延迟策略。例如:

    通过这种方式,可以在特定关联中启用延迟加载,而不受全局配置的影响。

  • 注意事项

    在实际应用中,可能会遇到以下问题:

  • 调试问题:在调试模式下,MyBatis会重新执行代码,导致延迟加载可能无法生效。为了规避这种情况,可以尝试以下方法:

    • 不进行调试打断,直接打印分割线并输出结果。
    @Testpublic void testResult() {  User user = userMapper.findUserById(1);  System.out.println("------------------查询OrderList分割线------------------");  System.out.println(user.getOrderList());}
    • 修改MyBatis核心配置文件,设置lazyLoadTriggerMethods为空:

    这些方法可以帮助开发者更好地判断延迟加载是否正常工作。

  • 通过以上方法,开发者可以充分利用MyBatis的延迟加载功能,优化数据库性能,同时在调试过程中也能避免因.debug模式导致的问题。

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

    你可能感兴趣的文章
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
    查看>>
    NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
    查看>>
    NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
    查看>>
    NIFI大数据进阶_NIFI集群知识点_集群的断开_重连_退役_卸载_总结---大数据之Nifi工作笔记0018
    查看>>
    NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
    查看>>
    NIFI大数据进阶_外部ZK模式集群1_实际操作搭建NIFI外部ZK模式集群---大数据之Nifi工作笔记0017
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_01_实际操作---大数据之Nifi工作笔记0029
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
    查看>>
    NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
    查看>>
    NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
    查看>>
    NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
    查看>>
    NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
    查看>>
    NIFI集群_队列Queue中数据无法清空_清除队列数据报错_无法删除queue_解决_集群中机器交替重启删除---大数据之Nifi工作笔记0061
    查看>>
    NIH发布包含10600张CT图像数据库 为AI算法测试铺路
    查看>>
    Nim教程【十二】
    查看>>
    Nim游戏
    查看>>
    NIO ByteBuffer实现原理
    查看>>
    Nio ByteBuffer组件读写指针切换原理与常用方法
    查看>>
    NIO Selector实现原理
    查看>>