Mybatis架构拾遗
2019-03-01 本文已影响34人
Real_man
SSM是项目开发中基础的组件,掌握其原理也是基本要求,今天再回顾一下Mybatis的一些细节
Mybatis:
Image result for mybatis architecture在其设计上,整体流程比Spring简单很多,也更直观一些:
- 首先加载xml配置文件
- xml配置文件中的各个节点都有对应的封装组件,这段逻辑主要在XMLConfigBuilder.parseConfiguration方法中,最终将整个配置组装为Mybatis的Configuration对象,这个对象在后续基本上也是会一直使用的
- 通过Configration对象构建DefaultSqlSessionFactory,根据配置创建SqlSession
在剩余的对数据库增删改查中,主要依靠SqlSesision来处理:
- sqlSession中包含Executor对象,Executor是真正进行数据库操作的对象
- 在执行的过程中,会根据配置创建newParameterHandler,newResultSetHandler,newStatementHandler,newExecutor。在创建对象之后会立刻用Plugins进行插件处理。插件主要是利用JDK的动态代理
- 在底层的执行方面依靠JDBC的statement进行执行
在数据源方面:
- 根据刚开始的配置文件进行解析,创建DataSourceFactory,默认有三种数据源,Pooled,Unpooled,JNDI
- 一般会使用PooledDataSource,在获取链接的时候,创建数据库连接池。
PooledDataSource.popConnection
- 数据源因为其是配置,存储在configuration中的environment对象里
获取连接:
- 创建PreParedStatement还是通过JDK中的Connection对象
- 而Connection对象通过Mybatis的Configuration生成的Transaction对象
- TransactionFactory通过配置文件中的transactionManager来配置,必须要指定的,不然会抛异常
- Transaction的实现类一般是将Connection对象放在自己的属性上
最后
其实基本上都是通过xml文件配置的,然后在解析配置的时候做了很多预先处理的工作,将创建的对象作为Configuration的属性,后续根据配置创建其它对象,然后进行操作。