标签:xml mapper JDBC 封装 配置文件 sql MyBatis 解析 包中
关于xml等解析的工具基本均包含在org.apache.ibatis.builder包中,有包名可知基本使用建造者模式。这个包的主要功能两个:
1、解析XML配置文件和映射文件,xml子包中;
2、解析注解形式的mapper声明,这部分功能在annotation中。
暂时仅分析xml配置文件方式的技术实现。
关于builder包中关于xml实现的UML图如下:
测试案例代码如下:
调试代码,跟踪xml解析过程及解析结果的保存:
一、代理对象的解析保存
1、
2、
3、
4、
5、
6、
7、
8、
二、MappedStatement解析保存(xxxmapper.xml解析)
1、
2、
3、
4、
5、
6、
三、数据源相关解析保存(datasource)
1、
2、
3、
以上将配置文件中数据源、sql及相应mapper的代理对象均保存在Configuration的属性中,分别是MappedStatement、environment、MappedRegistry。以上三个属性保证了对于数据库的操作的基本功能,剩下的就是对数据的实际操作了。剩下的工作谁做呢?Executor。
Executor在sqlsession生成的过程中作为其属性之一生成,具体如下:
关于执行器具体可参考https://www.cnblogs.com/ilovebath/p/14510697.html
那么这几个分离的过程,怎么执行关联一起执行数据库的操作的呢?客户端获取mapper代理对象(https://www.cnblogs.com/ilovebath/p/14511932.html)后,执行invoke方法。invoke方法中使用executor执行链接数据库、执行sql语句并返回结果映射。核心方法如下:
其中可以验证:1、获取数据库链接
2、预处理sql语句
3、参数化处理
标签:xml,mapper,JDBC,封装,配置文件,sql,MyBatis,解析,包中 来源: https://www.cnblogs.com/ilovebath/p/14608991.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。