https://blog.csdn.net/persistencegoing/article/details/84376427
SSM是项目开发中基础的组件,掌握其原理也是基本要求,今天再回顾一下Mybatis的一些细节
Mybatis:
Mybatis 插件原理https://www.jianshu.com/p/eedaf7bf4c32
Mybatis源码分析-整体设计(一)https://www.jianshu.com/p/d4d720933ba2
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
3.数据源因为其是配置,存储在configuration中的environment对象里
获取连接:
1.创建PreParedStatement还是通过JDK中的Connection对象
2.而Connection对象通过Mybatis的Configuration生成的Transaction对象
3.TransactionFactory通过配置文件中的transactionManager来配置,必须要指定的,不然会抛异常
4.Transaction的实现类一般是将Connection对象放在自己的属性上
image-20190228153122807
image-20190228153038582
最后
其实基本上都是通过xml文件配置的,然后在解析配置的时候做了很多预先处理的工作,将创建的对象作为Configuration的属性,后续根据配置创建其它对象,然后进行操作。
原文:https://blog.csdn.net/weixin_33943836/article/details/88306157
希望大家关注我一波,防止以后迷路,有需要的可以加群讨论互相学习java ,学习路线探讨,经验分享与java求职
群号:721 515 304