• spring 七种事务


    七种事务类型:

    1、propagation_required:支持当前事务,无事务,另起新事物

    2、propagation_required-new:新建事务,若有旧事务,挂起。

    3、propagation_supports:支持当前事务,无事务,以非事务执行

    4、propagation_mandatory:以事务方式执行,无事务,抛异常

    5、propagation_not_supported:不支持事务,如有事务,挂起

    6、propagation_never:以非事务执行,有事务,抛异常

    7、propagation_nested:内切事务

    具体解释如下:

    1: PROPAGATION_REQUIRED

      加入当前正要执行的事务不在另外一个事务里,那么就起一个新的事务。
      比如说,ServiceB.methodB的事务级别定义为PROPAGATION_REQUIRED, 那么由于执行ServiceA.methodA的时候,ServiceA.methodA已经起了事务。
      这时调用ServiceB.methodB,ServiceB.methodB看到自己已经运行在ServiceA.methodA的事务内部,就不再起新的事务。
      而假如ServiceA.methodA运行的时候发现自己没有在事务中,他就会为自己分配一个事务。
      这样,在ServiceA.methodA或者在ServiceB.methodB内的任何地方出现异常,事务都会被回滚。
      即使ServiceB.methodB的事务已经被提交,但是ServiceA.methodA在接下来fail要回滚,ServiceB.methodB也要回滚

    2: PROPAGATION_SUPPORTS

      如果当前在事务中,即以事务的形式运行,如果当前不再一个事务中,那么就以非事务的形式运行。

    3: PROPAGATION_MANDATORY

      必须在一个事务中运行。也就是说,他只能被一个父事务调用。否则,他就要抛出异常。

    4: PROPAGATION_REQUIRES_NEW

      这个就比较绕口了。
      比如我们设计ServiceA.methodA的事务级别为PROPAGATION_REQUIRED,ServiceB.methodB的事务级别为ROPAGATION_REQUIRES_NEW。
      那么当执行到ServiceB.methodB的时候,ServiceA.methodA所在的事务就会挂起,ServiceB.methodB会起一个新的事务,等待ServiceB.methodB的事务完成以后,他才继续执行。
      他与PROPAGATION_REQUIRED 的事务区别在于事务的回滚程度。因为ServiceB.methodB是新起一个事务,那么就是存在>两个不同的事务。
      如果ServiceB.methodB已经提交,那么ServiceA.methodA失败回滚,ServiceB.methodB是不会回滚的。
      如果ServiceB.methodB失败回滚,如果他抛出的异常被ServiceA.methodA捕获,ServiceA.methodA事务仍然可能提交。

    5: PROPAGATION_NOT_SUPPORTED

      当前不支持事务。
      比如ServiceA.methodA的事务级别是PROPAGATION_REQUIRED ,而ServiceB.methodB的事务级别是PROPAGATION_NOT_SUPPORTED。
      那么当执行到ServiceB.methodB时,ServiceA.methodA的事务挂起,而他以非事务的状态运行完,再继续ServiceA.methodA的事务。

    6: PROPAGATION_NEVER

      不能在事务中运行。假设ServiceA.methodA的事务级别是PROPAGATION_REQUIRED,而ServiceB.methodB的事务级别是PROPAGATION_NEVER,
      那么ServiceB.methodB就要抛出异常了。

    7: PROPAGATION_NESTED (没有在EJB中定义)

      理解Nested的关键是savepoint。
      他与PROPAGATION_REQUIRES_NEW的区别是:PROPAGATION_REQUIRES_NEW另起一个事务,将会与他的父事务相互独立;
      而Nested的事务和他的父事务是相依的,他的提交是要等和他的父事务一块提交的。
      也就是说,如果父事务最后回滚,他也要回滚的。
      而Nested事务的好处是他有一个savepoint。

    复制代码
    ServiceA {
      /**
      * 事务属性配置为 PROPAGATION_REQUIRED
      */
      void methodA() {
        try {
        //savepoint
        ServiceB.methodB(); //PROPAGATION_NESTED 级别
        } catch (SomeException) {
          // 执行其他业务
          ServiceC.methodC();
        }
      }
    }
    复制代码

      也就是说ServiceB.methodB失败回滚,那么ServiceA.methodA也会回滚到savepoint点上,ServiceA.methodA可以选择另外一个分支,比如

    ServiceC.methodC,继续执行,来尝试完成自己的事务。

    工作小总结,有错请指出,谢谢。
  • 相关阅读:
    关于报错”已有打开的于此Command相关联的DataReader,必须首先将它关闭。“的问题
    Dockerjenkins环境搭建跟配置
    Python+selenium 【第十章】封装config类,读取配置文件,封装驱动类,适配windows/mac
    —— “欢迎来到我的小屋”
    Python+selenium 【第九章】封装excel类,封装test_data类 读取测试元素信息
    Linux搭建docker
    Python+selenium 【第十二章】封装日志类优化其他方法并添加日志(异常处理)
    【selenium】Python自动化面试题
    Dockerjenkins容器安装python并配置环境变量
    【优化框架】新增期望结果,断言为mysql情况下动态化参数替换
  • 原文地址:https://www.cnblogs.com/zilanghuo/p/6668110.html
Copyright © 2020-2023  润新知