Mybatis架构拾遗

SSM是项目开发中基础的组件,掌握其原理也是基本要求,今天再回顾一下Mybatis的一些细节

Mybatis:

 
Mybatis架构拾遗
Image result for mybatis architecture

在其设计上,整体流程比Spring简单很多,也更直观一些:

  1. 首先加载xml配置文件
  2. xml配置文件中的各个节点都有对应的封装组件,这段逻辑主要在XMLConfigBuilder.parseConfiguration方法中,最终将整个配置组装为Mybatis的Configuration对象,这个对象在后续基本上也是会一直使用的
  3. 通过Configration对象构建DefaultSqlSessionFactory,根据配置创建SqlSession

在剩余的对数据库增删改查中,主要依靠SqlSesision来处理:

  1. sqlSession中包含Executor对象,Executor是真正进行数据库操作的对象
  2. 在执行的过程中,会根据配置创建newParameterHandler,newResultSetHandler,newStatementHandler,newExecutor。在创建对象之后会立刻用Plugins进行插件处理。插件主要是利用JDK的动态代理
  3. 在底层的执行方面依靠JDBC的statement进行执行

在数据源方面:

  1. 根据刚开始的配置文件进行解析,创建DataSourceFactory,默认有三种数据源,Pooled,Unpooled,JNDI
  2. 一般会使用PooledDataSource,在获取链接的时候,创建数据库连接池。
PooledDataSource.popConnection
  1. 数据源因为其是配置,存储在configuration中的environment对象里

获取连接:

  1. 创建PreParedStatement还是通过JDK中的Connection对象
  2. 而Connection对象通过Mybatis的Configuration生成的Transaction对象
  3. TransactionFactory通过配置文件中的transactionManager来配置,必须要指定的,不然会抛异常
  4. Transaction的实现类一般是将Connection对象放在自己的属性上
 
Mybatis架构拾遗
image-20190228153122807
 
Mybatis架构拾遗
image-20190228153038582

最后

其实基本上都是通过xml文件配置的,然后在解析配置的时候做了很多预先处理的工作,将创建的对象作为Configuration的属性,后续根据配置创建其它对象,然后进行操作。