spring 管理事务的方式有几种 ?
- 编程式事务,在代码中硬编码(不推荐使用)
- 声明式事务,在配置文件中配置(推荐使用)
- 声明式事务又分为两种:
- 基于 XML 的声明式事务
- 基于注解的声明式事务
spring 事务中的隔离级别有哪几种 ?
- TransactionDefinition 接口中定义了五个表示隔离级别的常量:
- TransactionDefinition.isolation_default:使用后端数据库默认的隔离级别,mysql 默认采用的 repeatable_read 隔离级别, oracle 默认采用的 read_committed 隔离级别
- TransactionDefinition.isolation_read_uncommitted:最低的隔离级别,允许读取尚未提交的数据变更,可能会导致脏读、幻读或不可重复读
- TransactionDefinition.isolation_read_committed:允许读取并发事务已经提交的数据,可以阻止脏读,但是幻读或不可重复读仍有可能发生
- TransactionDefinition.isolation_repeatable_read:对同一字段的多次读取结果都是一致的,除非数据是被本身事务自己所修改,可以阻止脏读和不可重复读,但幻读仍有可能发生
- TransactionDefinition.isolation_serializable:最高的隔离级别,完全服从 ACID 的隔离级别;所有的事务依次逐个执行,这样事务之间就完全不可能产生干扰,也就是说,该级别可以防止脏读、不可重复读以及幻读,但是这将严重影响程序的性能,通常情况下也不会用到该级别
spring 事务中哪几种事务传播行为?
- 支持当前事务的情况:
- TransactionDefinition.propagation_required(默认):如果当前存在事务,则加入该事务;如果当前没有事务,则创建一个新的事务
- TransactionDefinition.propagation_supports: 如果当前存在事务,则加入该事务;如果当前没有事务,则以非事务的方式继续运行
- TransactionDefinition.propagation_mandatory:如果当前存在事务,则加入该事务;如果当前没有事务,则抛出异常 (mandatory:强制性)
- 不支持当前事务的情况:
- TransactionDefinition.propagation_requires_new:创建一个新的事务,如果当前存在事务,则把当前事务挂起
- TransactionDefinition.propagation_not_supported:以非事务方式运行,如果当前存在事务,则把当前事务挂起
- TransactionDefinition.propagation_never:以非事务方式运行,如果当前存在事务,则抛出异常
- 其他情况
- TransactionDefinition.propagation_never:如果当前存在事务,则创建一个事务作为当前事务的嵌套事务来运行;如果当前没有事务,则该取值等价于TransactionDefinition.propagation_required
@Transactional(rollbackFor=Exception.class) 注解了解吗 ?
- 我们知道:Exception 分为运行时异常 RuntimeException 和非运行时异常,事务管理对于企业应用来说是至关重要的,即使出现异常情况,它也可以保证数据的一致性
- 当 @Transactional 注解作用于类上时,该类的所有 public 方法将都具有该类型的事务属性,同时,我们也可以在方法级别使用该标注来覆盖类级别的定义;如果类或者方法加了这个注解,那么这个类里面的方法抛出异常,就会回滚,数据库里面的数据也会回滚
- 在 @Transactional 注解中如果不配置 rollbackFor 属性,那么事物只会在遇到 RuntimeException 的时候才会回滚,加上 rollbackFor=Exception.class,可以让事物在遇到非运行时异常时也回滚
spring 事物失效的十种场景