MyBatis封装JDBC具体实现


  关于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、参数化处理

   

 

 

 

 

 

 

 

 

 

 

 

   

 

  

  

 

    

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM