MyBatis-事务管理机制(JDBC/Managed)

本文详细介绍了MyBatis中两种事务管理方式:JDBC和Managed。通过配置XML文件设置事务管理器,展示了JdbcTransaction和ManagedTransaction类的实现,包括连接获取、提交、回滚和关闭等操作。
摘要由CSDN通过智能技术生成

Mybatis管理事务是分为两种方式:

(1)使用JDBC的事务管理机制,就是利用java.sql.Connection对象完成对事务的提交
(2)使用MANAGED的事务管理机制,这种机制mybatis自身不会去实现事务管理,而是让程序的容器(JBOSS,WebLogic)来实现对事务的管理
在Mybatis的配置文件中可以配置事务管理方式如下:

  1. <?xml version="1.0" encoding="UTF-8"?>  
  2.  <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">  
  3.  <configuration>  
  4.      <environments default="development">  
  5.           <environment id="development">  
  6.               <!--配置事务的管理方式-->  
  7.               <transactionManager type="JDBC" />  
  8.               <!-- 配置数据库连接信息 -->  
  9.               <dataSource type="POOLED">  
  10.                   <property name="driver" value="com.mysql.jdbc.Driver" />  
  11.                  <property name="url" value="jdbc:mysql://localhost:3306/mybatis" />  
  12.                  <property name="username" value="root" />  
  13.                  <property name="password" value="XDP" />  
  14.              </dataSource>  
  15.          </environment>  
  16.      </environments>      
  17.  </configuration>  
<?xml version="1.0" encoding="UTF-8"?>
 <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">
 <configuration>
     <environments default="development">
          <environment id="development">
			  <!--配置事务的管理方式-->
              <transactionManager type="JDBC" />
              <!-- 配置数据库连接信息 -->
              <dataSource type="POOLED">
                  <property name="driver" value="com.mysql.jdbc.Driver" />
                 <property name="url" value="jdbc:mysql://localhost:3306/mybatis" />
                 <property name="username" value="root" />
                 <property name="password" value="XDP" />
             </dataSource>
         </environment>
     </environments>    
 </configuration>
Mybatis提供了一个事务接口Transaction,以及两个实现类jdbcTransaction和ManagedTransaction,当spring与Mybatis一起使用时,spring提供了一个实现类SpringManagedTransaction
Transaction接口:提供的抽象方法有获取数据库连接getConnection,提交事务commit,回滚事务rollback和关闭连接close,源码如下:

  1. //事务接口  
  2. ublic interface Transaction {  
  3.  /** 
  4.   * Retrieve inner database connection 
  5.   * @return DataBase connection 
  6.   * @throws SQLException 
  7.   */  
  8.   //获得数据库连接  
  9.  Connection getConnection() throws SQLException;  
  10.  /** 
  11.   * 提交 
  12.   * Commit inner database connection. 
  13.   * @throws SQLException 
  14.   */  
  15.  void commit() throws SQLException;  
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值