Mybatis 事务管理

mybatis的事务和数据源有着非常密切的联系。上文讲述了mybatis的数据源,本文要讲述的便是mybatis的事物

 

1.事务的分类


我们还是已一段xml配置文件为例

<environments default="development">
  <environment id="development">
    <transactionManager type="JDBC">
      <property name="..." value="..."/>
    </transactionManager>
    <dataSource type="POOLED">
      <property name="driver" value="${driver}"/>
      <property name="url" value="${url}"/>
      <property name="username" value="${username}"/>
      <property name="password" value="${password}"/>
    </dataSource>
  </environment>
</environments>

xml的transactionManager就是mybatis事务的类型。mybatis事务总共有两种类型。

1.JDBC:使用JDBC来管理实务
2.MANAGED:使用WEB容器来管理事务

 2.事务的创建


 事物的创建和Datasource和相似,在系统解析xml的时候生成一个工厂类,当需要生成一个sqlssesion的时候通过工厂类生成一个transaction对象,这个对象被executor对象持有。

生成事务工厂类

 生成事务

 

 3.事务的提交


 我们以一次sqlssesion.commit()为起点。来看下commit的内部究竟发生了什么(这里我们已JDBCTransaction为例)

1.调用executor的commit

2.调用transaction的commit

 

3.1JDBCTransaction调用connection的commit

 3.1ManagedTransaction调用connection的commit

由此可见JDBCTransaction其实只是对Connection做了包装。而ManagedTransaction什么都没做。

 

以上就是mybatis的事务介绍。

 

转载于:https://www.cnblogs.com/xmzJava/p/9126005.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值