spring 事务的七中传播行为五中隔离
Posted 暖暖
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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); }
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类似的操作。 |
事务的隔离(五):
DEFAULT 这是一个PlatfromTransactionManager默认的隔离级别,使用数据库默认的事务隔离级别.
未提交读(read uncommited) :脏读,不可重复读,虚读都有可能发生
已提交读 (read commited):避免脏读。但是不可重复读和虚读有可能发生
可重复读 (repeatable read) :避免脏读和不可重复读.但是虚读有可能发生.
串行化的 (serializable) :避免以上所有读问题.
mysql 默认:可重复读
以上是关于spring 事务的七中传播行为五中隔离的主要内容,如果未能解决你的问题,请参考以下文章