MyBatis源码分析-数据源及事务管理器获取过程

前一篇文章中,我们已经看到配置文件的解析过程,配置文件所有属性解析都在这个方法里XMLConfigBuilder的parseConfiguration方法,接下来我们先看下配置文件中数据源的获取过程。先看下数据源的结构

 parseConfiguration方法,

 数据源解析方法environmentsElement。
 先获取节点environments里的default的环境变量值,可以看到environments可以配置多个environment节点,既可以指定多个环境的数据源配置信息,然后在environments里的default里指定我们需要用哪个环境即可。

遍历environments的子节点的environment,然后获取值,environment节点里可以配置事务管理器和数据源信息,即transactionManager和dataSource。

①获取transactionManager的值使用transactionManagerElement方法

 获取transactionManager节点type属性的值,支持JDBC 和 MANAGED,type="JDBC" 代表使用JDBC的提交和回滚来管理事务,type="MANAGED" 代表事务管理器是当由应用服务器负责管理数据库连接生命周期的时候使用。这里使用了策略模式去选择数据源

JDBC 事务管理器被用作当应用程序负责管理数据库连接的生命周期(提交、回退等等)的时候。当你将TransactionManager 属性设置成 JDBC,MyBatis 内部将使用 JdbcTransactionFactory 类创建TransactionManager。例如,部署到 Apache Tomcat 的应用程序,需要应用程序自己管理事务。

 MANAGED 事务管理器是当由应用服务器负责管理数据库连接生命周期的时候使用。当你将
TransactionManager 属性设置成 MANAGED 时,MyBatis 内部使用 ManagedTransactionFactory 类创建事务管理器TransactionManager。例如,当一个JavaEE的应用程序部署在类似 JBoss,WebLogic,GlassFish 应用服务器上时,它们会使用 EJB 进行应用服务器的事务管理能力。在这些管理环境中,你可以使用 MANAGED 事务管理器。

关系图

 ②获取dataSource的值使用dataSourceElement方法

mybatis提供了3种数据源类型,分别是:POOLED,UNPOOLED,JNDI,
POOLED表示支持JDBC数据源连接池;
UNPOOLED表示不支持数据源连接池;
JNDI表示支持外部数据源连接池

关系图

 

 根据type获取到数据源工厂,然后将数据源信息设置到对象中,我们可以看到

DataSourceFactory接口有两个方法

 dataSourceElement方法将获取到的数据源属性的值,调用setProperties方法设置值,然后返回结果、在environmentsElement方法中又调用getDataSource方法

使用建造者模式进行赋值,最终构造一个Environment对象,设置到Configuration的environment属性中。

以上就是获取和设置数据源及事务管理器的逻辑。我们用流程图总结一下。 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值