八、【源码】细化XML语句构建器,完善静态SQL解析

源码地址:https://github.com/mybatis/mybatis-3/

仓库地址:https://gitcode.net/qq_42665745/mybatis/-/tree/08-optimize-xml-parse

细化XML语句构建器,完善静态SQL解析

这一节主要是优化XML解析SQL部分,流程大概为:

1.XMLConfigBuilder解析配置文件,先解析数据源信息,然后再解析SQL信息,拿到mapper元素下的地址

2.XMLMapperBuilder对上面拿到的mapper地址进行处理,根据标签拿到SQL,以select为例,拿到所有select的语句,每一个语句创建一个XMLStatementBuilder处理,处理完成后将这个mapper对应的namespace创建映射器工厂存到configuration中

3.拿到SQL对应的xml,解析id、参数类型、结果类型等信息,从configuration中拿到语言驱动,语言驱动是专门解析sql的,可以进行定制化扩展。

现在用的是XMLScriptBuilder将xml中的SQL构建可执行的SQL,将SQL做一些结点保证,取出SQL包装成StaticTextSqlNode结点放入list中,再包装成MixedSqlNode对象。

创建RawSqlSource对象,这里拿到的SQL是原始SQL,也就是带#{id}的SQL,这里调用SqlSourceBuilder做可执行SQL的构建,这里会替换原始sql中的#{id}的参数,替换成?,也就是预处理的sql,替换掉的参数都封装成一个个ParameterMapping对象中,最后将预处理SQL和替换下来的ParameterMapping列表封装成一个SqlSource。使用SqlSource对象创建MappedStatement对象并存入configuration中

相关推荐
努力学编程呀(๑•ี_เ•ี๑)1 分钟前
【在 IntelliJ IDEA 中切换项目 JDK 版本】
java·开发语言·intellij-idea
码农小卡拉10 分钟前
深入解析Spring Boot文件加载顺序与加载方式
java·数据库·spring boot
怣5015 分钟前
MySQL多表连接:全外连接、交叉连接与结果集合并详解
数据库·sql
向上的车轮18 分钟前
为什么.NET(C#)转 Java 开发时常常在“吐槽”Java:checked exception
java·c#·.net
Dragon Wu19 分钟前
Spring Security Oauth2.1 授权码模式实现前后端分离的方案
java·spring boot·后端·spring cloud·springboot·springcloud
跳动的梦想家h25 分钟前
环境配置 + AI 提效双管齐下
java·vue.js·spring
坚持就完事了27 分钟前
Java中的集合
java·开发语言
wjhx36 分钟前
QT中对蓝牙权限的申请,整理一下
java·数据库·qt
YCY^v^40 分钟前
JeecgBoot 项目运行指南
java·学习
人间打气筒(Ada)1 小时前
jenkins基于Pipeline发布项目
java·pipeline·jenkins·流水线·ci·cd·cicd