• Spring 事务的七种传播行为五种隔离四种特性


    事务的四种特性

    1. 原子性 (atomicity):强调事务的不可分割.
    2. 一致性 (consistency):事务的执行的前后数据的完整性保持一致.
    3. 隔离性 (isolation):一个事务执行的过程种,不应该受到其他事务的干扰
    4. 持久性(durability) :事务一旦结束,数据就持久到数据库

    事务的七种传播行为

    propagion_XXX :事务的传播行为

    1. propagion_required: 支持当前事务,如果不存在 就新建一个(默认)
    2. propagion_supports: 支持当前事务,如果不存在,就不使用事务
    3. propagion_mandatory: 支持当前事务,如果不存在,抛出异常
    4. propagion_requires_new:  如果有事务存在,挂起当前事务,创建一个新的事务
    5. propagion_not_supported: 以非事务方式运行,如果有事务存在,挂起当前事务
    6. propagion_never: 以非事务方式运行,如果有事务存在,抛出异常
    7. propagion_nested: 如果当前事务存在,则嵌套事务执行

    PROPAGATION_REQUIRED

    如果当前没有事务,就新建一个事务,如果已经存在一个事务种,加入到这个事务种。这是最常见的选择。(有A B  两个在方法C 里面调用了方法A和方法B如果A有异常执行失败,

    那么B方法也不会配执行)

    PROPAGATION_SUPPORTS

    支持当前事务,如果当前没有事务,就以非事务方式执行

    PROPAGATION_MANDATORY

    使用当前的事务,如果当前没有事务,就抛出异常。

    PROPAGATION_REQUIRES_NEW

    新建事务,如果当前存在事务,把当前事务挂起。

    理解:(方法A 方法B begin trans a method b() end )

    PROPAGATION_NOT_SUPPORTED

    以非事务方式执行操作,如果当前存在事务,就把当前事务挂起。A方法调用B方法 B不执行事务

    PROPAGATION_NEVER

    以非事务方式执行,如果当前存在事务,则抛出异常

    PROPAGATION_NESTED

    如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则执行与PROPAGATION_REQUIRED类似的操作。

      

    public enum Propagation {
    	
    	REQUIRED(TransactionDefinition.PROPAGATION_REQUIRED),
    	
    	SUPPORTS(TransactionDefinition.PROPAGATION_SUPPORTS),
    	
    	MANDATORY(TransactionDefinition.PROPAGATION_MANDATORY),
    	
    	REQUIRES_NEW(TransactionDefinition.PROPAGATION_REQUIRES_NEW),
    	
    	NOT_SUPPORTED(TransactionDefinition.PROPAGATION_NOT_SUPPORTED),
    	
    	NEVER(TransactionDefinition.PROPAGATION_NEVER),
    	
    	NESTED(TransactionDefinition.PROPAGATION_NESTED);
    }
    

      

    事务的五种隔离:案列

    1. DEFAULT: 这是一个PlatfromTransactionManager默认的隔离级别,使用数据库默认的事务隔离级别. 
    2. 未提交读(read uncommited) :脏读,不可重复读,虚读都有可能发生 
    3. 已提交读 (read commited):避免脏读。但是不可重复读和虚读有可能发生 
    4. 可重复读 (repeatable read) :避免脏读和不可重复读.但是虚读有可能发生. 
    5. 串行化的 (serializable) :避免以上所有读问题. 

     Mysql 默认:可重复读,Oracle 默认:读已提交  

  • 相关阅读:
    postgres--流复制
    postgres--wal
    postgres--vacuum
    postgres10配置huge_pages
    Postgres间隔大量写IO的解决办法
    PostgreSQL配置文件--其他
    PostgreSQL配置文件--AUTOVACUUM参数
    PostgreSQL配置文件--实时统计
    PostgreSQL配置文件--日志和错误
    PostgreSQL配置文件--QUERY TUNING
  • 原文地址:https://www.cnblogs.com/fanBlog/p/9599220.html
Copyright © 2020-2023  润新知