MyBatis封装JDBC具体实现

  关于xml等解析的工具基本均包含在org.apache.ibatis.builder包中,有包名可知基本使用建造者模式。这个包的主要功能两个:
  1、解析XML配置文件和映射文件,xml子包中;
  2、解析注解形式的mapper声明,这部分功能在annotation中。
  暂时仅分析xml配置文件方式的技术实现。
关于builder包中关于xml实现的UML图如下:

MyBatis封装JDBC具体实现

 

   测试案例代码如下:

MyBatis封装JDBC具体实现

  调试代码,跟踪xml解析过程及解析结果的保存:

  一、代理对象的解析保存

  1、

 MyBatis封装JDBC具体实现

 

   2、

  MyBatis封装JDBC具体实现

 

   3、

  MyBatis封装JDBC具体实现

  4、

  MyBatis封装JDBC具体实现

   5、

  MyBatis封装JDBC具体实现

   6、

  MyBatis封装JDBC具体实现

   7、

  MyBatis封装JDBC具体实现

   8、

  MyBatis封装JDBC具体实现

   二、MappedStatement解析保存(xxxmapper.xml解析)

  1、

  MyBatis封装JDBC具体实现

 

   2、

   MyBatis封装JDBC具体实现

 

   3、

  MyBatis封装JDBC具体实现

 

   4、

  MyBatis封装JDBC具体实现

 

   5、

  MyBatis封装JDBC具体实现

 

   6、

  MyBatis封装JDBC具体实现

   三、数据源相关解析保存(datasource)

  1、

  MyBatis封装JDBC具体实现

 

   2、

MyBatis封装JDBC具体实现

  3、

  MyBatis封装JDBC具体实现

 

   以上将配置文件中数据源、sql及相应mapper的代理对象均保存在Configuration的属性中,分别是MappedStatement、environment、MappedRegistry。以上三个属性保证了对于数据库的操作的基本功能,剩下的就是对数据的实际操作了。剩下的工作谁做呢?Executor。

  MyBatis封装JDBC具体实现

 

  Executor在sqlsession生成的过程中作为其属性之一生成,具体如下:

MyBatis封装JDBC具体实现

   关于执行器具体可参考https://www.cnblogs.com/ilovebath/p/14510697.html

  那么这几个分离的过程,怎么执行关联一起执行数据库的操作的呢?客户端获取mapper代理对象(https://www.cnblogs.com/ilovebath/p/14511932.html)后,执行invoke方法。invoke方法中使用executor执行链接数据库、执行sql语句并返回结果映射。核心方法如下:

  MyBatis封装JDBC具体实现

 

   MyBatis封装JDBC具体实现

 

   其中可以验证:1、获取数据库链接

         2、预处理sql语句

         3、参数化处理

   

 

 

 

 

 

 

 

 

 

 

 

   

 

  

  

 

    

 

MyBatis封装JDBC具体实现

上一篇:重新安装MySQL服务


下一篇:动态SQL