Spring如何处理事务

21 篇文章 1 订阅
12 篇文章 1 订阅

​ Spring当中支持编程式事务和声明式事务

  1. **编程式事务:**通过Transaction Template手动管理事务,硬编码 ,实际应用中很少使用。

  2. 声明式事务(基于XML和注解): 推荐使用(代码侵入性最小),实际是通过AOP实现。

    优点:不需要在业务代码中添加事务管理的代码,只需要在配置文件中做相应的事务规则就行。

    缺点:声明式事务只能针对方法级别,无法控制代码级别的事务管理。

    Spring中事务传播级别:

    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. PROPAGATION_REQUIRED:默认传播行为。如果当前存在事务,则加⼊该事务;如果当前没有事务,则创建⼀个新的事务。
    2. PROPAGATION_SUPPORTS:如果当前存在事务,则加⼊该事务;如果当前没有事务,则以⾮事务的⽅式继续运⾏ 。
    3. PROPAGATION_MANDATORY:如果当前存在事务,则加⼊该事务;如果当前没有事务,则抛出异常。(mandatory:强制性) 。

    不⽀持当前事务的情况:

    1. PROPAGATION_REQUIRES_NEW:创建⼀个新的事务,如果当前存在事务,则把当前事务挂起。
    2. PROPAGATION_NOT_SUPPORTED:以⾮事务⽅式运⾏,如果当前存在事务,则把当前事务挂起。
    3. PROPAGATION_NEVER:以⾮事务⽅式运⾏,如果当前存在事务,则抛出异常。
    4. PROPAGATION_NESTED:如果当前存在事务,则在嵌套事务内执行;如果当前没有事务,则按REQUIRED属性执行。

    Spring中事务传播级别:

    public enum Isolation {
    
    	DEFAULT(TransactionDefinition.ISOLATION_DEFAULT),
    
    	READ_UNCOMMITTED(TransactionDefinition.ISOLATION_READ_UNCOMMITTED),
    
    	READ_COMMITTED(TransactionDefinition.ISOLATION_READ_COMMITTED),
    
    	REPEATABLE_READ(TransactionDefinition.ISOLATION_REPEATABLE_READ),
    
    	SERIALIZABLE(TransactionDefinition.ISOLATION_SERIALIZABLE);
        
        ......
    
    }
    
    
    1. DEFAULT: 使⽤后端数据库默认的隔离级别, Mysql默认采⽤的 REPEATABLE_READ隔离级别 Oracle 默认采⽤的 READ_COMMITTED隔离级别.
    2. READ_UNCOMMITTED: 最低的隔离级别,允许读取尚未提交的数据变更, 可能会导致脏读、幻读或不可重复读
    3. READ_COMMITTED: 允许读取并发事务已经提交的数据, 可以阻⽌脏读,但是幻读或不可重复读仍有可能发⽣
    4. REPEATABLE_READ: 对同⼀字段的多次读取结果都是⼀致的,除⾮数据是被本身事务⾃⼰所修改, 可以阻⽌脏读和不可重复读,但幻读仍有可能发⽣。
    5. SERIALIZABLE: 最⾼的隔离级别,完全服从ACID的隔离级别。所有的事务依次逐个执⾏,这样事务之间就完全不可能产⽣⼲扰,也就是说, 该级别可以防⽌脏读、不可重复读以及幻读。但是这将严重影响程序的性能。通常情况下也不会⽤到该级别。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值