五(补充三)MyBatis封装JDBC具体实现
通过https://www.cnblogs.com/ilovebath/p/14531263.html,实现了类似Mybatis的基本框架,对于Mybatis的框架应该有了比较直观的了解。对于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、参数化处理
总结Mybatis对持久层的操作就是借助核心的四大组件Executor、StatementHandler、ParameterHandler、ResultSetHandler,如下:
其整体架构如下,可以清晰地发现四大组件的核心地位: