【MyBatis】源码学习 05 - 关于 xml 文件解析的分析

news2025/1/10 20:49:06

文章目录

    • 前言
    • 参考目录
    • 学习笔记
      • 1、章节目录概览
      • 2、`14.3`:`SqlSourceBuilder` 类与 `StaticSqlSource` 类
      • 3、`14.4.2`:`ResultMapResolver` 类
      • 3.1、测试代码说明
      • 3.2、结果集 `userMap` 解析流程
      • 3.3、结果集 `getGirl` 解析流程
      • 3.4、鉴别器 `discriminator` 解析流程
      • 4、`14.6`:XML 文件解析
      • 5、`14.6.2`:配置文件解析
      • 6、`14.6.3`:数据库操作语句解析
      • 7、`14.6.4`:Statement 解析
      • 8、`14.7`:注解映射的解析

前言

本文内容对应的是书本第 14 章的内容,主要是关于 builder 包的学习,本章节的内容比较多,每一小节都有相应的例子进行说明,也附带了源码的注释说明,因此本文只是选择了本章节一部分的内容来进行 Debug 分析说明。

参考目录

  • 《通用源码阅读指导书:MyBatis源码详解》
    本文主要内容来自 第14章 builder包
  • 《通用源码阅读指导书——MyBatis源码详解》配套示例
    书中涉及的 Demo 示例,本文示例在 Demo13 的基础上进行了简单改造。

与上篇一样,需要说明的是,书中使用的框架版本和本文(本专栏)使用的版本不一样。

名称书中版本专栏版本
MyBatis3.5.23.5.11+
Spring Boot2.X3.X
JDK817+

随着版本的升级迭代,会有一些内容不尽相同,需要结合着进行学习。

学习笔记

1、章节目录概览

由于我在微信读书看书的时候,电子版对于书本章节里面的小节并没有进行详细的划分,有些小节的内容并没有在目录体现出来,对于想要快速查找资料不太方便,所以下面简单的做了整理,方便后面复习时进行对照查找。

(加粗的部分是下面会进行分析的内容)

  • 14.1 建造者模式
  • 14.2 建造者基类与工具类
  • 14.3 SqlSourceBuilder类与StaticSqlSource类
  • 14.4 CacheRefResolver类和ResultMapResolver类
    • 14.4.1 CacheRefResolver类
    • 14.4.2 ResultMapResolver类
  • 14.5 ParameterExpression类
  • 14.6 XML文件解析
    • 14.6.1 XML文件的声明解析
    • 14.6.2 配置文件解析
    • 14.6.3 数据库操作语句解析
    • 14.6.4 Statement解析
    • 14.6.5 引用解析
  • 14.7 注解映射的解析
    • 14.7.1 注解映射的使用
    • 14.7.2 注解映射解析的触发
    • 14.7.3 直接注解映射的解析
    • 14.7.4 间接注解映射的解析

2、14.3SqlSourceBuilder 类与 StaticSqlSource

SqlSourceBuilder 类能够将 DynamicSqlSource 和 RawSqlSource 中的“#{}”符号替换掉,从而将它们转化为 StaticSqlSource。

#{} 其实是 xml 文件中很重要的参数占位符,而 SqlSourceBuilder 的作用就是把占位符解析并转换成为 SQL,下面通过一个简单的示例来 Debug 看一下这个过程。

测试的SQL:

	<select id="selectById" resultType="User">
        SELECT * FROM `user` WHERE id = #{id}
    </select>

SqlSourceBuilder#parse
在这里插入图片描述

GenericTokenParser#parse
在这里插入图片描述

在这里插入图片描述

解析完成后,返回 SqlSourceBuilder#parse 方法构建 StaticSqlSource

在这里插入图片描述

StaticSqlSource#StaticSqlSource
在这里插入图片描述

3、14.4.2ResultMapResolver

借助于 MapperBuilderAssistant 的 addResultMap 方法,ResultMapResolver 完成了ResultMap 的继承关系解析,最终给出一个解析完继承关系之后的ResultMap 对象。

3.1、测试代码说明

跟参考目录 Demo 中的 Demo13 类似,测试代码如下:
在这里插入图片描述

ResultMap 对象的解析由主节点到子节点依次进行,下面的分析也分成三个部分,分别是 userMapgetGirl 以及 discriminator

3.2、结果集 userMap 解析流程

XMLMapperBuilder#resultMapElements
在这里插入图片描述

XMLMapperBuilder#resultMapElement
在这里插入图片描述

resultMap 继承关系的解析由 ResultMapResolver 类来完成。

ResultMapResolver#resolve
在这里插入图片描述

在这里插入图片描述

借助于 MapperBuilderAssistant 的 addResultMap 方法,ResultMapResolver 完成了ResultMap 的继承关系解析,最终给出一个解析完继承关系之后的ResultMap 对象。

MapperBuilderAssistant#addResultMap
在这里插入图片描述

在这里插入图片描述

3.3、结果集 getGirl 解析流程

XMLMapperBuilder#resultMapElements
在这里插入图片描述

XMLMapperBuilder#resultMapElement
在这里插入图片描述

ResultMapResolver#resolve
在这里插入图片描述

MapperBuilderAssistant#addResultMap
在这里插入图片描述

在这里插入图片描述

3.4、鉴别器 discriminator 解析流程

XMLMapperBuilder#resultMapElement
在这里插入图片描述

XMLMapperBuilder#processDiscriminatorElement
在这里插入图片描述

解析结果:
在这里插入图片描述

4、14.6:XML 文件解析

解析的语句:

<!DOCTYPE mapper   PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

在这里插入图片描述

在这里插入图片描述

5、14.6.2:配置文件解析

先抛出结论:

XMLConfigBuilder在 MyBatis的配置解析中起到了引导的作用,正是从它的parse方法开始,引发了配置文件和映射文件的解析。

放到代码当中,实际上是创建 SqlSessionFactory 时,XMLConfigBuilder 对 XML 文件进行解析。

执行方法的调用链如下:

  • org.apache.ibatis.session.SqlSessionFactoryBuilder#build
    • org.apache.ibatis.builder.xml.XMLConfigBuilder#parse
      • org.apache.ibatis.builder.xml.XMLConfigBuilder#parseConfiguration
        • org.apache.ibatis.builder.xml.XMLConfigBuilder#environmentsElement

XML 配置文件 mybatis-config.xml
在这里插入图片描述

XMLConfigBuilder#parseConfiguration
在这里插入图片描述

XMLConfigBuilder#environmentsElement
在这里插入图片描述

一共三部分:默认环境,事务管理器 TransactionFactory,数据源 DataSourceFactory

参数 XNode context
在这里插入图片描述

默认环境
在这里插入图片描述

事务管理器 TransactionFactory

XMLConfigBuilder#transactionManagerElement
在这里插入图片描述

数据源 DataSourceFactory

XMLConfigBuilder#dataSourceElement
在这里插入图片描述

最终解析完成 XMLConfigBuilder#environmentsElement
在这里插入图片描述

6、14.6.3:数据库操作语句解析

parse 方法为解析的入口方法,然后调用configurationElement 方法逐层完成解析。

和配置文件解析过程类似,执行方法的调用链如下:

  • org.apache.ibatis.builder.xml.XMLConfigBuilder#parseConfiguration
    • org.apache.ibatis.builder.xml.XMLConfigBuilder#mapperElement
      • org.apache.ibatis.builder.xml.XMLMapperBuilder#parse
        • org.apache.ibatis.builder.xml.XMLMapperBuilder#configurationElement

由 configurationElement(parser.evalNode(“/mapper”))语句触发后,系统会依次解析映射文件的各个节点。

XMLMapperBuilder#parse
在这里插入图片描述

参数 XNode context
在这里插入图片描述

  • cacheRefElement:缓存引用
  • cacheElement:缓存
  • parameterMapElement:参数映射
  • resultMapElements:结果映射
  • sqlElement:sql
  • buildStatementFromContext:从上下文构建语句

7、14.6.4:Statement 解析

这里主要是承接上一小节对 buildStatementFromContext 方法进行了说明。

执行方法的调用链如下:

  • org.apache.ibatis.builder.xml.XMLMapperBuilder#buildStatementFromContext
    • org.apache.ibatis.builder.xml.XMLStatementBuilder#parseStatementNode

XMLStatementBuilder#parseStatementNode
在这里插入图片描述

在这里插入图片描述

MapperBuilderAssistant#addMappedStatement
在这里插入图片描述

在这里插入图片描述

解析完成的 statement
在这里插入图片描述

在这里插入图片描述

8、14.7:注解映射的解析

这里主要是对于书中没有详细说明的 泛型桥接方法 进行简单的拓展。

关于这一方面我和 ChatGPT 来回讨论了几次然后有了以下说明:

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

还有一些补充说明作为辅助理解:
在这里插入图片描述

在这里插入图片描述

关于该方法的参数讨论:
在这里插入图片描述

在这里插入图片描述

(完)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/383610.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

汽车电子CAN协议上位机软件的设计实现

先不说汽车电子,通常上位机软件如何实现呢?作为控制嵌入式设备的PC端软件,主要功能就是配置和读取嵌入式设备基于特定接口的交互信息,所以首先需要控制一个通讯设备作为中间的通讯媒介。比如sscom5.13.1就可以作为上位机软件工具,它需要一个具有usb转UART通讯的接口设备或…

C#中,Elasticsearch.Net判断空字符串

之前有个业务需求&#xff0c;由于最开始存储到es里的&#xff0c;是默认空字符串&#xff0c;后面程序取数据时&#xff0c;发现需要取空字符串的数据时&#xff0c;不好取出来。 字符串的字段如图&#xff1a; 实际数据如图&#xff1a; 用的是C#语言&#xff0c;使用的是E…

【算法笔记】递归与回溯

递归与回溯 To Iterate is Human, to Recurse, Divine. —L. Peter Deutsch 人理解迭代&#xff0c;神理解递归。 —L. Peter Deutsch 1.什么是递归呢 递归形象描述&#xff1a; 你打开面前这扇门&#xff0c;看到屋里面还有一扇门。 你走过去&#xff0c;发现手中的钥匙还可以…

【Spark分布式内存计算框架——Spark Streaming】11. 应用案例:百度搜索风云榜(下)实时窗口统计

5.5 实时窗口统计 SparkStreaming中提供一些列窗口函数&#xff0c;方便对窗口数据进行分析&#xff0c;文档&#xff1a; http://spark.apache.org/docs/2.4.5/streaming-programming-guide.html#window-operations 在实际项目中&#xff0c;很多时候需求&#xff1a;每隔一…

数智未来,AI赋能——第四届OpenI/O 启智开发者大会昇腾人工智能应用专场圆满举行!

为提升启智社区与鹏城实验室在人工智能开源领域的影响力&#xff0c;促进社区成员与开源生态圈伙伴的合作。2月25日上午&#xff0c;第四届OpenI/O 启智开发者大会昇腾人工智能应用专场分论坛在深圳人才研修院举办&#xff0c;进一步促进与发挥企业间资源共通的优势&#xff0c…

【ROS2知识】关于colcon编译和ament指定

一、说明 这里说说编译和包生成的操作要点&#xff0c;以python包为例。对于初学者来说&#xff0c;colcon和ament需要概念上搞清楚&#xff0c;与此同时&#xff0c;工作空间、包、节点在一个工程中需要熟练掌握。本文以humble版的ROS2&#xff0c;进行python编程的实现。 二、…

【408之计算机组成原理】计算机系统概述

目录前言一、计算机的发展历程1. 计算机发展的四代变化2. 计算机元件的更新换代3. 计算机软件的发展二、计算机系统层次结构1. 计算机系统的组成2. 冯诺依曼体系结构3. 计算机的功能部件1. 输入设备2. 输出设备3. 存储器4. 运算器5. 控制器三、 分析计算机各个部件在执行代码中…

【算法】阿里面试题-编码实现20亿个整数,找出某个数X是否存在其中

1.海量数据去重-BitMap位图解决方案 需求&#xff08;面试题&#xff09; 一个32位4G内存的操作系统&#xff0c;在20亿个整数&#xff0c;找出某个数X是否存在其中 假如是java语言&#xff0c;int占4字节&#xff0c;1字节8位&#xff08;1 byte 8 bit&#xff09; 方式一&…

Mockito 入门

目录1.什么是 Mock 测试&#xff1f;2.Mockito简介3.在 SpringBoot 单元测试中使用 Mockito3.1 Maven依赖&#xff1a;3.2 UserService.java3.3 User.java3.4 thenReturn系列方法&#xff08;测试桩&#xff09;3.5 thenThrow系列方法3.6 verify 系列方法4.Spring中mock任何容器…

计算机组成原理-动态链接库-笔记

Linux 下的 ELF 文件格式 Windows 的可执行文件格式是一种叫作PE&#xff08;Portable Executable Format&#xff09;的文件格式 动态链接库 这些机器码必须是“地址无关”的。也就是说&#xff0c;我们编译出来的共享库文件的指令代码&#xff0c;是地址无关码&#xff08;…

10个可以实现高效工作与在线赚钱的 AI 工具网站

自 2020 年以来&#xff0c;内容开发领域已经感受到人工智能工具的存在。 目前&#xff0c;营销人员和内容创作者正在利用这些工具来加快他们的工作流程。 如果您拥有最流行的 AI 工具之一&#xff0c;例如 CopyAI、Jasper AI 或 Content at Scale&#xff0c;您可能正在考虑…

申论套卷 | 要点杂、乱、碎的材料如何快速分类整理?

试卷来源&#xff1a;2020年全国联考上半年材料1A省C市Y区文化馆&#xff08;非物质文化遗产保护中心&#xff09;作为政府设立的公益性公共文化事业单位&#xff0c;始终坚持公益文化发展方向&#xff0c;面向基层、贴近百姓、服务大众&#xff0c;积极组织各种大型活动&#…

Ubuntu中安装matelab2020a

Ubuntu中安装matelab2020a1 matelab下载2 安装步骤3 激活matelab4 创建快捷方式我的Ubuntu版本是20.041 matelab下载 matelab官网https://www.mathworks.com/ 点击右上角的get matelab&#xff0c;进入下载页面 没有账号的同学可以先去注册一个&#xff0c;推荐使用教育邮箱&…

错误: tensorflow.python.framework.errors_impl.OutOfRangeError的解决方案

近日&#xff0c;在使用CascadeRCNN完成目标检测任务时&#xff0c;我在使用这个模型训练自己的数据集时出现了如下错误&#xff1a; tensorflow.python.framework.errors_impl.OutOfRangeError: PaddingFIFOQueue _1_get_batch/batch/padding_fifo_queue is closed and has in…

前端JS内存管理

JS内存管理 内存原理&#xff1a; 任何变成语言在执行的时候都需要操作系统来分配内存&#xff0c;只是有些语言需要手动管理分配的内存有些语言有专门来管理内存的方式 如 JVM 了解以上的概念之后&#xff0c;我们再来了解一下大致的内存周期 分配需要的内存使用内存在不使用…

Linux- 系统随你玩之--好用到炸裂的系统级监控、诊断工具

文章目录1、前言2、lsof介绍2.1、问题来了&#xff1a; 所有用户都可以采用该命令吗&#xff1f;3、 服务器安装lsof3.1、安装3.2、检查安装是否正常。4、lsof 命令4.1、常用功能选项4.2、输出内容4.2.1 、FD和 TYPE列5、 lsof 命令实操常见用法6 、常用组合命令7、 结语1、前言…

OpenHarmony 3.2 Beta Audio——音频渲染

一、简介Audio是多媒体子系统中的一个重要模块&#xff0c;其涉及的内容比较多&#xff0c;有音频的渲染、音频的采集、音频的策略管理等。本文主要针对音频渲染功能进行详细地分析&#xff0c;并通过源码中提供的例子&#xff0c;对音频渲染进行流程的梳理。二、目录foundatio…

无线WiFi安全渗透与攻防(一)之无线安全环境搭建

无线安全环境搭建 1.802.11标准 &#xff08;1&#xff09;.概念 802.11标准是1997年IEEE最初制定的一个WLAN标准&#xff0c;工作在2.4GHz开放频段&#xff0c;支持1Mbit/s和2Mbit/s的数据传输速率&#xff0c;定义了物理层和MAC层规范&#xff0c;允许无线局域网及无线设备…

Crack:LightningChart .NE​​T 10.4.1中的新功能

数据游标 Lightningchart .NET UWP 展示应用 在以前的版本中&#xff0c;LightningChart .NET 提供了不同的工具来实现数据跟踪功能&#xff0c;但都需要额外的用户编码。 现在可以使用 DataCursor 浏览 ViewXY 系列。系列数据值由这个新类/对象显示在鼠标位置或鼠标位置附近。…

【matplotlib】可视化解决方案——如何解决matplotlib中文乱码问题

问题概述 Matplotlib 默认不支持中文字体&#xff0c;这是因为 matplotlib 只支持 ASCII 字符&#xff0c;但是国人使用 matplotlib 肯定需要中文标注。如下图所示&#xff0c;当不对 Matplotlib 进行设置&#xff0c;而直接使用中文时&#xff0c;绘制的图像会出现中文乱码。…