• mysql 事务的传播机制


    mysql 事务的传播机制

    1.PROPAGATION_REQUIRED=0:
    如果当前存在事务,则加入该事务;如果当前没有事务,则创建一个新的事务。
    无父事务时:子事务作为独立事务执行
    有父事务时:子事务中的操作串入父事务中执行,并且一起提交,一个操作失败全部回滚
    
    2.PROPAGATION_SUPPORTS=1:
    如果当前存在事务,则加入该事务;如果当前没有事务,则以非事务的方式继续运行。
    无父事务时:以非事务方式执行
    有父事务时:加入父事务执行,等同于PROPAGATION_REQUIRED
    
    3.PROPAGATION_MANDATORY=2:
    如果当前存在事务,则加入该事务;如果当前没有事务,则抛出异常。
    无父事务时:抛出异常
    有父事务时:加入父事务执行,等同于PROPAGATION_REQUIRED
    
    4.PROPAGATION_REQUIRES_NEW=3:
    创建一个新的事务,如果当前存在事务,则把当前事务挂起。
    挂起(Suspend):通知TransactionManager不再检查某事务的状态,直到Resume
    AbstractPlatformTransactionManager. handleExistingTransaction()
    
    无父事务时:子事务新建事务作为独立事务执行
    有父事务时:子事务新建事务作为独立事务执行,独立提交;
    
    T1{
      O(A);
      T2{
        O(B);
        O(C);
      };
      O(D);
    };
    如此示例:
    子事务T2不受父事务T1回滚的影响,但仍作为T1的子逻辑,
    O(D)失败,O(A)回滚,T2中的事务不回滚;
    T2失败回滚,T1捕获异常后,可以选择提交或回滚,未捕获异常,同T2一起回滚。
    
    5.NOT_SUPPORTED=4:
    
    以非事务方式运行,如果当前存在事务,则把当前事务挂起。
    无父事务时:以非事务方式执行
    有父事务时:挂起父事务,自己按照无事务方式运行
    子事务自身无回滚,出现异常若向上抛,可能导致父事务回滚
    父事务回滚时,不会影响子事务。
    
    6.NEVER=5:
    
    以非事务方式运行,如果当前存在事务,则抛出异常。
    无父事务时:以非事务方式执行
    有父事务时:抛出异常(若不处理会导致父事务回滚)
    
    7.NESTED=6:
    
    如果当前存在事务,则创建一个事务作为当前事务的嵌套事务来运行
    无父事务时:创建独立事务,等同于PROPAGATION_REQUIRED
    有父事务时:嵌套在父事务之内
    子事务依赖父事务:子事务于父事务提交时提交;父事务回滚,子事务也回滚。
    Savepoint:子事务回滚时,父事务不回滚

  • 相关阅读:
    【JavaP6大纲】MySQL篇:如何实现 MySQL 的读写分离?MySQL 主从复制原理是啥?如何解决 MySQL 主从同步的延时问题?
    【JavaP6大纲】MySQL篇:现在有一个未分库分表的系统,未来要分库分表,如何设计才可以让系统从未分库分表动态切换到分库分表上?
    快速搭建PHP开发环境(PhpStorm+EasyPHP)
    iBatis开发者手册翻译(目录)
    iBatis开发者手册翻译(章节一、引言)
    asp.net 数据操作三步曲(一) :)
    一事归一事
    闲言碎语话心得你给我多少钱
    研发过程之代码评审
    让她自己来
  • 原文地址:https://www.cnblogs.com/djq-jone/p/15070665.html
Copyright © 2020-2023  润新知