美文网首页
Spring的事务(传播机制)

Spring的事务(传播机制)

作者: _River_ | 来源:发表于2021-05-30 23:18 被阅读0次
     Spring事务的作用:在代码逻辑与数据库进行交互时,尽可能保证数据库持久化数据的正确性;
    
     Spring事务的隔离级别与数据库的隔离级别一致,请查看其他相关的资料;通过设置@Transaction的isolation的属性     
     Spring事务的传播机制 ,处理方法与方法之间各种事务的关系: 通过设置@Transaction的propagation的属性
     
    本文章仅讲解Spring事务的传播机制:
    
    public enum Isolation {
        DEFAULT(-1),
        READ_UNCOMMITTED(1),
        READ_COMMITTED(2),
        REPEATABLE_READ(4),
        SERIALIZABLE(8);
    }
    
    public enum Propagation {
        REQUIRED(0),
        SUPPORTS(1),
        MANDATORY(2),
        REQUIRES_NEW(3),
        NOT_SUPPORTED(4),
        NEVER(5),
        NESTED(6);
    }
    
    1:required(默认隔离级别)
    如果当前没有事务,就创建一个新的事务,如果当前存在事务,就加入该事务,该设置是最常用的默认设置;
    
    @Transactional(propagation= Propagation.REQUIRED)
    public void methodA(){
        methodB();
        // do something
    }
    
    @Transactional(propagation= Propagation.REQUIRED)
    public void methodB(){
        // do something
    }
    
    
    调用methdoA,如果methodB发生异常,触发事务回滚,也会methodA中的也会回滚。
    
    2:supports
    支持当前事务,如果当前存在事务,就加入该事务,如果当前不存在事务,就以非事务执行。
    
    @Transactional(propagation= Propagation.REQUIRED)
    public void methodA(){
        methodB();
        // do something
    }
    
    @Transactional(propagation= Propagation.SUPPORTS)
    public void methodB(){
        // do something
    }
    
    如果调用methodA,再调用methodB,MehtodB会加入到MethodA的开启的当前事务中。
    如果直接调用methodB,当前没有事务,就以非事务执行。
    
    3:mandatory
    支持当前事务,如果当前存在事务,就加入该事务,如果当前不存在事务,就抛出异常。
    
    @Transactional(propagation= Propagation.REQUIRED)
    public void methodA(){
        methodB();
        // do something
    }
    
    @Transactional(propagation= Propagation.MANDATORY)
    public void methodB(){
        // do something
    }
    
    
    如果调用methodA,再调用methodB,MehtodB会加入到MethodA的开启的当前事务中。
    如果直接调用methodB,当前没有事务,就会抛出异常。
    
    4:requires_new
    创建新事务,无论当前存不存在事务,都创建新事务。
    
    @Transactional(propagation= Propagation.REQUIRED)
    public void methodA(){
        // do something pre
        methodB();
        // do something post
    }
    
    @Transactional(propagation= Propagation.REQUIRES_NEW)
    public void methodB(){
        // do something
    }
    
    
    调用methodA,会先开启事务1,执行A的something pre的代码。
    再调用methodB,methdoB会开启一个事务2,再执行自身的代码。
    最后在执行methodA的something post。
    
    如果methodB发生异常回滚,只是methodB中的代码回滚,不影响methodA中的代码。
    如果methodA发生异常回滚,只回滚methodA中的代码,不影响methodB中的代码。
    
    5:not_supported
    以非事务方式执行操作,如果当前存在事务,就把当前事务挂起。
    
    @Transactional(propagation= Propagation.REQUIRED)
    public void methodA(){
        methodB();
        // do something
    }
    
    @Transactional(propagation= Propagation.NOT_SUPPORTED)
    public void methodB(){
        // do something
    }
    
    
    调用methodA,再调用methodB,methodA开启的事务会methodB中被挂起,methodB内部抛出异常不会回滚。
    methodA内的代码发生异常会回滚。直接调用methodB,不会开启事务。
    
    6:never
    以非事务方式执行操作,如果当前存在事务,则抛出异常。
    
    @Transactional(propagation= Propagation.REQUIRED)
    public void methodA(){
        methodB();
        // do something
    }
    
    @Transactional(propagation= Propagation.NEVER)
    public void methodB(){
        // do something
    }
    
    
    如果调用methodA,再调用methodB,MehtodB会加入到MethodA的开启的当前事务中。此时会抛出异常。
    如果直接调用methodB,当前没有事务,正常运行。
    
    7:nested
    如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则按REQUIRED属性执行。
    
    @Transactional(propagation= Propagation.REQUIRED)
    public void methodA(){
        // do something pre
        methodB();
        // do something post
    }
    
    @Transactional(propagation= Propagation.NESTED)
    public void methodB(){
        // do something
    }
    
    
    调用methodA,开启一个事务,执行something pre的代码,设置回滚点savepoint,
    再调用methodB的代码,如果methodB里抛出异常,此时回滚到之前的saveponint。
    再然后执行methodA里的something post的代码,最后提交或者回滚事务。
    
    嵌套事务,外层的事务如果回滚,会导致内层的事务也回滚;
    但是内层的事务如果回滚,仅仅是回滚自己的代码,不影响外层的事务的代码。
    

    相关文章

      网友评论

          本文标题:Spring的事务(传播机制)

          本文链接:https://www.haomeiwen.com/subject/jbqvsltx.html