Spring事务 之 事务自动提交

一、MySQL数据库事务自动提交    

对于mysql数据库,默认情况下,数据库处于自动提交模式。每一条语句处于一个单独的事务中,在这条语句执行完毕时,如果执行成功则隐式的提交事务,如果执行失败则隐式的回滚事务。对于正常的事务管理,是一组相关的操作处于一个事务之中,因此必须关闭数据库的自动提交模式,下面是查看方式:

        查看是否自动提交命令(ON表示开启自动提交,值为1,OFF表示关闭自动提交,值为0):

    show variables like  'autocommit' ;
       关闭自动提交后,则用户将一直处于某个事务中,直到执行一条commit提交或rollback语句才会结束当前事务重新开始一个新的事务。

二、spring连接

  如果结合Spring来获取数据库连接,就不用担心,spring会将底层连接的自动提交特性设置为false,先看下Spring事务配置:

<!-- 配置事务 -->  
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">  
    <property name="dataSource" ref="dataSource" />  
</bean>  
<tx:annotation-driven transaction-manager="transactionManager"/>
上面配置中,重要的是类:org.springframework.jdbc.datasource.DataSourceTransactionManager,看其对自动提交的处理:

    protected void doBegin(Object transaction, TransactionDefinition definition) {  
       
        //......  
       
        if(con.getAutoCommit()) {  
            txObject.setMustRestoreAutoCommit(true);  
            if(this.logger.isDebugEnabled()) {  
                this.logger.debug("Switching JDBC Connection [" + con + "] to manual commit");  
            }  
            con.setAutoCommit(false);  
        }  
        
        //......  
             
    }  

三、建议:当一个连接关闭时,如果有未提交的事务则回滚任何未提交的事务(C3P0默认的策略,C3P0的autoCommitOnClose属性默认是false)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值