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

作者 : admin 本文共796个字,预计阅读时间需要2分钟 发布时间: 2024-06-10 共2人阅读

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

仓库地址:http://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中

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

本站无任何商业行为
个人在线分享 » 八、【源码】细化XML语句构建器,完善静态SQL解析
E-->