MyBatis如何处理延迟加载?
大家好,我是锋哥。今天分享关于【MyBatis如何处理延迟加载?】面试题。希望对大家有帮助;

MyBatis如何处理延迟加载?
1000道 互联网大厂Java工程师 精选面试题-Java资源分享网
MyBatis 支持 延迟加载(Lazy Loading),允许在需要数据时才从数据库加载,而不是在查询结果第一次返回时就立即加载所有数据。这种方式可以优化性能,减少不必要的数据库查询,提高应用的响应速度和资源利用效率。
延迟加载的原理
延迟加载的核心思想是,将关联对象或集合的加载推迟到真正需要时才进行加载,而不是在主查询时一次性加载。这可以通过两种主要方式实现:
- 延迟加载单个关联对象(如:查询时只加载主对象,关联对象在访问时才加载)
- 延迟加载集合属性(如:查询时不加载集合,只有在访问集合时才进行查询)
MyBatis 通过代理模式(代理对象)和懒加载机制来实现延迟加载。以下是 MyBatis 如何处理延迟加载的详细信息:
1. 开启延迟加载
MyBatis 默认开启延迟加载机制,但你需要在配置文件中指定相关配置。
在 mybatis-config.xml 配置文件中:
<settings><setting name="lazyLoadingEnabled" value="true"/><setting name="aggressiveLazyLoading" value="false"/><setting name="lazyLoadTriggerMethods" value="equals,clone,hashCode"/>
</settings>
lazyLoadingEnabled:开启延迟加载,默认为true,启用后,MyBatis 会对关联的对象进行延迟加载。aggressiveLazyLoading:是否强制加载所有的延迟加载属性。默认为false,即延迟加载会在实际访问时才加载。lazyLoadTriggerMethods:定义了触发延迟加载的 Java 方法,通常是equals、hashCode或clone等方法。当调用这些方法时,MyBatis 会检查是否需要延迟加载关联对象。
2. 延迟加载的配置
在 MyBatis 中,可以通过以下几种方式配置延迟加载:
2.1 使用 resultMap 配置延迟加载
延迟加载通常与映射关系中的关联对象一起使用。例如,当你在 resultMap 中映射一个对象时,可以通过 fetchType 来指定加载策略。
<resultMap id="orderResultMap" type="Order"><id property="id" column="order_id"/><result property="user" column="user_id" fetchType="lazy"/>
</resultMap>
fetchType="lazy":表示该属性(关联对象)采用延迟加载,只有在访问时才会从数据库加载。fetchType="eager":表示该属性(关联对象)采用立即加载,查询时就会一起加载。
fetchType 是 @Many 和 @One 注解的属性,控制关联对象的加载方式。
2.2 使用 @One 和 @Many 注解进行延迟加载
如果使用注解方式进行映射,可以使用 @One 和 @Many 注解来指定加载策略:
public class Order {private int id;private String name;@One(fetchType = FetchType.LAZY)private User user; // 延迟加载 User 对象
}
在这种配置下,user 关联对象会在访问时触发延迟加载。
2.3 在查询时设置延迟加载
在某些情况下,你可能希望通过在查询方法中控制延迟加载。你可以在 Mapper 中使用 @Select 注解来控制:
@Select("SELECT * FROM orders WHERE id = #{id}")
@Results({@Result(property = "user", column = "user_id", one = @One(select = "com.example.mapper.UserMapper.selectUser", fetchType = FetchType.LAZY))
})
Order selectOrderById(int id);
此时 user 关联对象会被延迟加载。
3. 如何触发延迟加载
延迟加载是通过代理对象实现的。当你访问被延迟加载的关联对象时,MyBatis 会触发数据库查询。
例如,假设有一个 Order 对象,它有一个关联的 User 对象,在访问 Order 对象时,User 不会立即加载,只有当你访问 Order.getUser() 时,MyBatis 才会执行 SQL 查询,加载 User 数据。
Order order = orderMapper.selectOrderById(1);
User user = order.getUser(); // 此时会触发延迟加载,查询 User 数据
4. 延迟加载的代理机制
为了支持延迟加载,MyBatis 在内部使用 代理模式 来创建一个代理对象。当你访问延迟加载的属性时,代理对象会触发实际的数据库查询,并将查询结果赋给原始对象。代理对象会在数据库查询后进行填充,并返回给调用者。
- JDK 动态代理:当延迟加载的对象实现了接口时,MyBatis 会使用 JDK 动态代理来延迟加载。
- CGLIB 动态代理:当延迟加载的对象没有实现接口时,MyBatis 会使用 CGLIB 动态代理来实现。
5. 注意事项
-
性能问题:虽然延迟加载有助于减少不必要的数据库查询,但过度使用延迟加载也可能导致 N+1 查询问题。例如,如果你有一个包含多个订单的列表,每个订单的用户都是延迟加载的,那么可能会触发多次数据库查询(一次查询订单表,之后每个订单查询一次用户表)。可以通过
<fetchType="eager">或<join fetch>等优化策略来避免此问题。 -
事务问题:延迟加载通常需要在同一个事务范围内进行。如果在关闭事务后访问延迟加载的属性,可能会抛出
LazyInitializationException异常。为了避免这种问题,可以使用 OpenSessionInView 模式,确保事务在视图渲染期间保持开启。
总结
MyBatis 提供了强大的延迟加载功能,它通过代理模式、fetchType 配置以及延迟加载触发机制来实现数据的按需加载。配置合理的延迟加载能够优化性能,减少不必要的数据库查询,但也需要小心处理 N+1 查询问题 和 事务管理。
相关文章:
MyBatis如何处理延迟加载?
大家好,我是锋哥。今天分享关于【MyBatis如何处理延迟加载?】面试题。希望对大家有帮助; MyBatis如何处理延迟加载? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 MyBatis 支持 延迟加载(Lazy Loading&am…...
前端网络之【浏览器跨域问题分析与解决方案】
文章目录 同源策略同源与异源跨域的限制场景解决方案 CORS 请求分类 简单请求预检请求 注意点一 【关于Cookie】注意点二 【关于跨域获取响应头】 JSONP 基本流程 代理服务器 如何选择对应方案 同源策略 **同源策略是一套浏览器的安全策略机制,当一个源的文档和脚…...
LeetCode:3218. 切蛋糕的最小总开销 I(贪心 Java)
目录 3218. 切蛋糕的最小总开销 I 题目描述: 实现代码与解析: 贪心 原理思路: 3218. 切蛋糕的最小总开销 I 题目描述: 有一个 m x n 大小的矩形蛋糕,需要切成 1 x 1 的小块。 给你整数 m ,n 和两个数…...
前端下载后端文件流,文件可以下载,但是打不开,显示“文件已损坏”的问题分析与解决方案
目录 场景还原 相关代码开发者工具 - 网络请求记录 问题排查 定位改bug 总结 场景还原 我在前端使用axios接收后端xlsx表格文件流并下载,xlsx文件能够下载成功,但是打开却显示文件无法打开 相关代码 请求API封装:Content–Type以及responseType经核…...
PageRank Web页面分级算法 HNUST【数据分析技术】(2025)
1.理论知识 算法原理PageRank 通过网络浩瀚的超链接关系来确定一个页面的等级。 Google 把从 A 页面到 B 页面的链接解释为A页面给B页面投票, Google 根据投票来源(甚至来源的来源, 即链接到A页面的页面)和投票目标的等级来决定新…...
数字IC前端学习笔记:脉动阵列的设计方法学(四)
相关阅读 数字IC前端https://blog.csdn.net/weixin_45791458/category_12173698.html?spm1001.2014.3001.5482 引言 脉动结构(也称为脉动阵列)表示一种有节奏地计算并通过系统传输数据的处理单元(PEs)网络。这些处理单元有规律地泵入泵出数据以保持规则…...
对话 Project Astra 研究主管:打造通用 AI 助理,主动视频交互和全双工对话是未来重点
Project Astra 愿景之一:「系统不仅能在你说话时做出回应,还能在持续的过程中帮助你。」 近期,Google DeepMind 的 YouTube 频道采访了 Google DeepMind 研究主管格雷格韦恩 (Greg Wayne)。 格雷格韦恩的研究工作为 DeepMind 的诸多突破性成…...
NetApp 存储设备巡检作业指导书
NetApp 存储设备巡检作业指导书 一、目的 本指导书旨在指导管理员通过 SSH 或 Console 登录 NetApp FAS2552 存储系统,切换节点并进行日常管理操作。 二、适用范围 适用于基于 NetApp ONTAP 操作系统的 FAS2552 存储环境。 三、前提条件 网络和权限要求࿱…...
adb无法连接到安卓设备【解决方案】报错:adb server version (40) doesn‘t match this client (41);
下载老版本Platformtoolshttps://dl.google.com/android/repository/platform-tools_r28.0.2-windows.zip?hlzh-cn 替换原来的platform-tools文件夹即可。 问题原因分析:电脑端adb client版本(41)和安卓端adb …...
每天五分钟机器学习:核函数
本文重点 在学习支持向量机算法之前,我们要继续学习一些数学基础,本文我们将学习核函数的概念。当数据线性不可分的时候,此时就需要核函数出场了,它可以将低维不可分的数据映射到高维可分数据,此时就可以完成数据分类了。 核函数的定义 核函数K(x, y)定义为两个数据点x…...
Word窗体联动Excel实现级联组合框
在Word中的使用用户窗体(UserForm)定制界面如下图所示,其中控件如下(忽略Label控件): CompanyName 组合框Attention 组合框CommandButton1 按钮 现在需要实现级联组合框效果,即用户在 CompanyN…...
RAG实战:构建基于本地大模型的智能问答系统
RAG实战:构建基于本地大模型的智能问答系统 引言 在当今AI快速发展的时代,如何构建一个既智能又可靠的问答系统是一个重要课题。本文将介绍如何使用RAG(检索增强生成)技术,结合本地大模型,构建一个高效的智…...
Docker 部署 plumelog 最新版本 实现日志采集
1.配置plumelog.yml version: 3 services:plumelog:#此镜像是基于plumelog-3.5.3版本image: registry.cn-hangzhou.aliyuncs.com/k8s-xiyan/plumelog:3.5.3container_name: plumelogports:- "8891:8891"environment:plumelog.model: redisplumelog.queue.redis.redi…...
TCP/IP 邮件
TCP/IP邮件是互联网通信中非常重要的应用之一。当我们发送电子邮件时,我们实际上并没有直接使用TCP/IP协议,而是通过电子邮件程序,例如微软的Outlook、莲花软件的Notes或Netscape Communicator等来实现。这些电子邮件程序背后使用了不同的TCP…...
FreeSql
官网 实体特性 Ado 它包括所有对 SQL 操作的封装,提供 ExecuteReader、ExecuteDataSet、ExecuteDataTable、ExecuteNonQuery、ExecuteScalar 等方法,使用起来和传统 SqlHelper 一样。 1、安装包 Install-Package FreeSql Install-Package FreeSql.Prov…...
记一次前端Vue项目国际化解决方案
背景 有一个vue项目,要实现国际化功能,能够切换中英文显示,因为该项目系统的用户包括了国内和国外用户。 需求 1、页面表单上的所有中文标签要国际化,包括表单属性标签、表格列头标签等, title“数量”;…...
JS进阶-手写Promise
一、什么是Promise 在Promise A规范中规定,Promise是一个有一个符合规范的then方法的对象或者函数。 1.关于then then接收onFulfilled和onRejected两个可选参数;then必须返回一个新的Promise对象;如果onFulfilled是一个函数 在状态切换为f…...
PCL点云库入门——PCL库点云滤波算法之直通滤波(PassThrough)和条件滤波(ConditionalRemoval)
0、滤波算法概述 PCL点云库中的滤波算法是处理点云数据不可或缺的一部分,它们能够有效地去除噪声、提取特征或进行数据降维。例如,使用体素网格滤波(VoxelGrid)可以减少点云数据量,同时保留重要的形状特征。此外&#…...
ioctl回顾
一、ioctl协议的命令组成 cmd本质为一个32位的数字,共分为四段: [31-30]:读写方向dir,分为无数据(_IO)、读数据(_IOR)、写数据(_IOW)、读写数据(_IOWR)四种模式; [29-16]:传递数据的大小size,一般利用其宏_IO、_IOR…...
jquery-validate在前端数据校验中的应用以及remote异步调用实践-以若依为例
目录 前言 一、关于Jquery Validate组件 1、validate是什么 2、内置验证方式及触发方式 3、自定义验证规则 二、基本验证实战以及Remote验证 1、基本验证实现 2、remote校验方式 三、总结 前言 随着技术的不断演进,在我们的日常开发过程中,大家一…...
新手零基础入门:在快马平台上运行你的第一个yolov8检测程序
今天想和大家分享一个特别适合机器学习新手的实践项目——用yolov8完成第一个目标检测程序。作为刚接触计算机视觉的小白,我最初被各种环境配置和术语搞得晕头转向,直到发现用InsCode(快马)平台可以跳过繁琐的步骤,直接体验模型效果。 为什么…...
PID调参不再玄学:用自平衡小车实战,带你搞懂比例、积分、微分到底在干嘛
PID调参实战:用自平衡小车拆解比例、积分、微分的控制艺术 平衡车在桌面上稳稳立住的那一刻,仿佛打破了物理定律——这个看似简单的动作背后,是控制理论中最经典的PID算法在发挥作用。但翻开任何一本自动控制教材,满页的微分方程…...
【Python MCP服务器开发终极模板】:2026年生产级架构、安全加固与AI运维集成全指南
第一章:Python MCP服务器开发模板的演进与2026核心定位Python MCP(Model–Control–Protocol)服务器架构自2018年首次在开源社区实践以来,经历了从单体脚本、Flask轻量封装,到基于ASGI的异步协议栈重构的三阶段跃迁。2…...
Cloudflared实战:从零搭建安全内网穿透隧道
1. 为什么需要内网穿透? 很多开发者和运维人员都遇到过这样的尴尬:你在本地搭建了一个Web服务或者API接口,想给同事或者客户演示,却发现因为没有公网IP,对方根本无法访问。传统解决方案可能需要申请固定IP、配置路由器…...
Fourier Neural Operator (FNO) 在偏微分方程求解中的核心思想与应用
1. 从传统方法到FNO:偏微分方程求解的进化之路 偏微分方程(PDE)在工程和科学领域无处不在,从天气预报到飞机设计,从量子力学到金融衍生品定价。传统数值解法如有限差分法(FDM)和有限元法&#x…...
如何用DeepSeek高效处理学术论文审稿?5个实用提示词模板分享
如何用DeepSeek高效处理学术论文审稿?5个实用提示词模板分享 学术论文的审稿过程往往让研究者们又爱又恨——它既是提升研究质量的必经之路,又是耗时费力的繁琐环节。想象一下这样的场景:凌晨两点,你刚收到三位审稿人总计20页的修…...
基于浏览器端异步检测的B站用户成分分析方案:社区互动效率提升92%的技术实现
基于浏览器端异步检测的B站用户成分分析方案:社区互动效率提升92%的技术实现 【免费下载链接】bilibili-comment-checker B站评论区自动标注成分油猴脚本,主要为原神玩家识别 项目地址: https://gitcode.com/gh_mirrors/bi/bilibili-comment-checker …...
Simulink 中2-D Assignment 模块的进阶应用与批量赋值技巧
1. 从零认识2-D Assignment模块 第一次在Simulink里看到Assignment模块时,我完全没意识到这个小方块能玩出这么多花样。简单来说,它就是个专门给数组"改作业"的工具——你可以精确指定要修改数组中的哪些元素,就像老师用红笔批改试…...
G-Helper终极解决方案:华硕笔记本风扇与性能问题完全指南
G-Helper终极解决方案:华硕笔记本风扇与性能问题完全指南 【免费下载链接】g-helper Lightweight, open-source control tool for ASUS laptops and ROG Ally. Manage performance modes, fans, GPU, battery, and RGB lighting across Zephyrus, Flow, TUF, Strix,…...
Linux内核中的驱动程序开发高级话题
Linux内核中的驱动程序开发高级话题 引言 驱动程序是Linux内核中负责与硬件设备交互的重要组成部分,它为操作系统和硬件之间提供了桥梁。随着硬件技术的发展和系统复杂性的增加,驱动程序开发面临着越来越多的挑战。本文将深入探讨Linux内核中驱动程序开发…...
