分享

Spring事务之七(事务自动提交)

 quasiceo 2018-09-08

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

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

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

show variables like 'autocommit';

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

二、Spring连接

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

  1. <!-- 配置事务 -->
  2. <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
  3. <property name="dataSource" ref="dataSource" />
  4. </bean>
  5. <tx:annotation-driven transaction-manager="transactionManager"/>

上面配置中,重要的是类:org.springframework.jdbc.datasource.DataSourceTransactionManager,看其对自动提交的处理:

  1. protected void doBegin(Object transaction, TransactionDefinition definition) {

  2. //......

  3. if(con.getAutoCommit()) {
  4. txObject.setMustRestoreAutoCommit(true);
  5. if(this.logger.isDebugEnabled()) {
  6. this.logger.debug("Switching JDBC Connection [" + con + "] to manual commit");
  7. }
  8. con.setAutoCommit(false);
  9. }

  10. //......

  11. }

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

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多