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 事务的七中传播行为五中隔离的主要内容,如果未能解决你的问题,请参考以下文章

浅析Spring事务传播行为和隔离级别

Spring事务:传播行为与隔离级别

SPRING事务传播行为数据隔离级别

Spring事务隔离级别和传播特性

简述spring 的事务传播行为和 隔离级别

Spring的传播行为与隔离级别