Spring中的事务隔离级别和传播行为
作者:xiaoguangtouqiang 发布时间:2022-07-21 18:18:24
Spring的事务隔离级别和事务的传播行为是面试中经常考察的问题,做个简单的总结。
传播行为
在SpringBoot中通过Transactional的propagation属性来指定,Transactional注解的具体源码如下所示
public @interface Transactional {
@AliasFor("transactionManager")
String value() default "";
@AliasFor("value")
String transactionManager() default "";
Propagation propagation() default Propagation.REQUIRED;
Isolation isolation() default Isolation.DEFAULT;
}
可以看出,默认的值是Propagation.REQUIRED;
其他的还有:
1>
PROPAGATION_REQUIRED
支持当前事务,假设当前没有事务。就新建一个事务。2>
PROPAGATION_SUPPORTS
支持当前事务,假设当前没有事务,就以非事务方式运行。3>
PROPAGATION_MANDATORY
支持当前事务,假设当前没有事务,就抛出异常。4>
PROPAGATION_REQUIRES_NEW
新建事务,假设当前存在事务。把当前事务挂起。5>
PROPAGATION_NOT_SUPPORTED
以非事务方式运行操作。假设当前存在事务,就把当前事务挂起。6>
PROPAGATION_NEVER
以非事务方式运行,假设当前存在事务,则抛出异常。7>
PROPAGATION_NESTED
如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则进行与PROPAGATION_REQUIRED类似的操作。
举个例子进行说明
ServiceA {
void methodA() {
ServiceB.methodB();
}
}
ServiceB {
void methodB() {
}
}
1>PROPAGATION_REQUIRED
如果当前执行的事务不在另外一个事务里,就新起一个事务;ServiceB和 ServiceA在同一个事务里面,ServiceB如果异常,则整个事务认为是执行失败的,即便是在A里面try catch了异常也会导致A和B都回滚;同样,即便B执行成功,A执行报错产生异常,那么A和B都会回滚的;
2>PROPAGATION_SUPPORTS
假设当前在事务中。即以事务的形式执行。假设当前不再一个事务中,那么就以非事务的形式执行;
3>PROPAGATION_MANDATORY
支持当前事务,假设当前没有事务,就抛出异常,也就是说他必须在一个父事务中去执行;否则就会抛出异常;
4>PROPAGATION_REQUIRES_NEW
新建事务,假设当前存在事务,把当前事务挂起;比如服务A的事务级别是PROPAGATION_REQUIRED,那么服务B的级别是PROPAGATION_REQUIRES_NEW;那么当运行到ServiceB.methodB的时候,ServiceA.methodA所在的事务就会挂起。
ServiceB.methodB会起一个新的事务,等待ServiceB.methodB的事务完毕以后,他才继续运行;跟PROPAGATION_REQUIRED的区别是会新起一个事务,而不是使用父事务,所以是两个截然不同的事务,ServiceB的执行报错,如果被ServiceA捕获了,不会影响到ServiceA的回滚;
5>PROPAGATION_NOT_SUPPORTED
当前不支持事务,比方ServiceA.methodA的事务级别是PROPAGATION_REQUIRED 。
而ServiceB.methodB的事务级别是PROPAGATION_NOT_SUPPORTED ,那么当执行到ServiceB.methodB时。
ServiceA.methodA的事务挂起。而他以非事务的状态执行完,再继续ServiceA.methodA的事务。
6>PROPAGATION_NEVER
不能在事务中执行。
如果ServiceA.methodA的事务级别是PROPAGATION_REQUIRED。
而ServiceB.methodB的事务级别是PROPAGATION_NEVER ,那么ServiceB.methodB就要抛出异常了。
7>PROPAGATION_NESTED
理解Nested的关键是savepoint。
他与PROPAGATION_REQUIRES_NEW的差别是,PROPAGATION_REQUIRES_NEW另起一个事务。将会与他的父事务相互独立。
而Nested的事务和他的父事务是相依的,他的提交是要等和他的父事务一块提交的。
也就是说,假设父事务最后回滚。他也要回滚的。
来源:https://blog.csdn.net/xiaoguangtouqiang/article/details/81224511


猜你喜欢
- 下载地址在这里:http://dotnetzip.codeplex.com/下载到的包里有很多个dll文件,一般引用Ionic.Zip.dl
- 红黑树红黑树是一种数据结构与算法课堂上常常提到但又不会细讲的树,也是技术面试中经常被问到的树,然而无论是书上还是网上的资料,通常都比较刻板难
- Sentinel流控模式Sentinel流量控制主要有以下几种模式:直接失败模式:在达到流量控制阈值后,直接拒绝请求,返回错误信息。关联模式
- 目录效果展示实现原理实现步骤完整代码展示效果展示实现原理首先需要生成绘制小花的坐标点,坐标点的横坐标是根据控件的宽度随机生成的,而纵坐标则设
- 嗯,就是BASE64,不用多想,本来计划是要跟上一篇字符串压缩一起写的,用来实现将一个文件可以用json或者text等方式进行接口之间的传输
- 下面就列出配置eclipse联想功能(代码的提示功能)的步骤:1. 打开Eclipse,然后“window”→“Preferences”2.
- 效果图:完全代码(下方有详细解读) private void textBox1_TextChanged(object sender, Eve
- 本文实例讲述了C#中WinForm跨线程访问控件的实现方法,分享给大家供大家参考。具体实现方法如下:1、跨线程访问控件委托和类的定义usin
- 一、原理1、不变模式(不可变对象)在并行软件开发过程中,同步操作似乎是必不可少的。当多线程对同一个对象进行读写操作时,为了保证对象数据的一致
- 1、什么是值传递,什么是引用传递?值传递(pass by value)是指在调用函数时将实际参数复制一份传递到函数中,这样在函数中如果对参数
- 在实际应用中,很可能我们希望自己的app在按下返回键的时候并不退出,而是像按home键一样仅仅返回桌面,而程序仍然在后台运行着。要怎么实现这
- 说明:曾经在网上看过花样繁多的分页,很多都号称如何通用,但很多时候往往不尽如人意:有在分页类中还加入URL地址信息的,有在分页类中还进行分页
- 一、Maven聚合开发_继承关系 Maven中
- 1.pom文件导入依赖<!-- kafka --><dependency> <groupId>
- 一,背景之所以会想到一个服务同时使用eureka和nacos,是因为遇到一个需求,配置数据是存储在nacos的配置中,然后使用该配置的服务却
- 为什么需要多线程?模型的简化,如某些程序是由多个相对独立任务的运行:图形界面的出现,输入、输出的阻塞多核CPU的更好利用异步行为的需要Jav
- 这个是由于快捷键冲突造成的:所以可以查应用比如:1)搜狗输入法中设置的语句2)QQ音乐的快捷键3)有道词典的快键键把上面找的快键键删除,那么
- 第一种方法:string s=abcdeabcdeabcde;string[] sArray=s.Split(c) ;foreach(str
- 目录Static基本规则:1. static方法2. static变量3. static代码块4. static内部类5. static静态
- ContentProvider是内容提供者,可以跨进程提供数据。大家都知道,ContentProvider的启动,是在Application