八、【源码】细化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中

相关推荐
天上掉下来个程小白6 分钟前
HttpClient-03.入门案例-发送POST方式请求
java·spring·httpclient·苍穹外卖
ModestCoder_16 分钟前
将一个新的机器人模型导入最新版isaacLab进行训练(以unitree H1_2为例)
android·java·机器人
橙序研工坊36 分钟前
MySQL的进阶语法7(索引-B+Tree 、Hash、聚集索引 、二级索引(回表查询)、索引的使用及设计原则
数据库·sql·mysql
a1800793108037 分钟前
软件工程面试题(二十二)
java·面试·软件工程
RainbowSea40 分钟前
4. RabbitMQ 发布确认的配置详细说明
java·消息队列·rabbitmq
robin_suli1 小时前
Spring事务的传播机制
android·java·spring
青云交1 小时前
Java 大视界 -- Java 大数据在智能电网电力市场交易数据分析与策略制定中的关键作用(162)
java·大数据·数据分析·交易策略·智能电网·java 大数据·电力市场交易
m0Java门徒1 小时前
Java 递归全解析:从原理到优化的实战指南
java·开发语言
云徒川1 小时前
【设计模式】原型模式
java·设计模式·原型模式
张张张3122 小时前
4.2学习总结 Java:list系列集合
java·学习