Spring 事务的七种传播行为五种隔离四种特性
事务的四种特性
- 原子性 (atomicity):强调事务的不可分割.
- 一致性 (consistency):事务的执行的前后数据的完整性保持一致.
- 隔离性 (isolation):一个事务执行的过程种,不应该受到其他事务的干扰
- 持久性(durability) :事务一旦结束,数据就持久到数据库
事务的七种传播行为
propagion_XXX :事务的传播行为
- propagion_required: 支持当前事务,如果不存在 就新建一个(默认)
- propagion_supports: 支持当前事务,如果不存在,就不使用事务
- propagion_mandatory: 支持当前事务,如果不存在,抛出异常
- propagion_requires_new: 如果有事务存在,挂起当前事务,创建一个新的事务
- propagion_not_supported: 以非事务方式运行,如果有事务存在,挂起当前事务
- propagion_never: 以非事务方式运行,如果有事务存在,抛出异常
- 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); }
事务的五种隔离:案列
- DEFAULT: 这是一个PlatfromTransactionManager默认的隔离级别,使用数据库默认的事务隔离级别.
- 未提交读(read uncommited) :脏读,不可重复读,虚读都有可能发生
- 已提交读 (read commited):避免脏读。但是不可重复读和虚读有可能发生
- 可重复读 (repeatable read) :避免脏读和不可重复读.但是虚读有可能发生.
- 串行化的 (serializable) :避免以上所有读问题.
Mysql 默认:可重复读,Oracle 默认:读已提交