Spring中声明式事务的注解@Transactional的参数的总结(REQUIRED和REQUIRES_NEW的与主方法的回滚问题)
来源:互联网 发布:中超 球员数据 编辑:程序博客网 时间:2024/05/16 08:03
一、事务的传播行为
1.介绍
当事务方法被另一个事务方法调用时,必须指定事务应该如何传播。例如:方法可能继续在现有事务中运行,也可能开启一个新事务,并在自己的事务中运行。
2.属性
事务的传播行为可以由传播属性指定。Spring定义了7种类传播行为。
系统默认的是REQUIRED属性。
常用的是REQUIRED和REQUIRES_NEW,所以此处只说明这两种属性。
二、事务的隔离级别
1.数据库事务并发问题
假设现在有两个事务:Transaction01和Transaction02并发执行。
①脏读
[1]Transaction01将某条记录的AGE值从20修改为30。
[2]Transaction02读取了Transaction01更新后的值:30。
[3]Transaction01回滚,AGE值恢复到了20。
[4]Transaction02读取到的30就是一个无效的值。
②不可重复读
[1]Transaction01读取了AGE值为20。
[2]Transaction02将AGE值修改为30。
[3]Transaction01再次读取AGE值为30,和第一次读取不一致。
③幻读
[1]Transaction01读取了STUDENT表中的一部分数据。
[2]Transaction02向STUDENT表中插入了新的行。
[3]Transaction01读取了STUDENT表时,多出了一些行。
2.隔离级别
数据库系统必须具有隔离并发运行各个事务的能力,使它们不会相互影响,避免各种并发问题。一个事务与其他事务隔离的程度称为隔离级别。SQL标准中规定了多种事务隔离级别,不同隔离级别对应不同的干扰程度,隔离级别越高,数据一致性就越好,但并发性越弱。
①读未提交:READUNCOMMITTED
允许Transaction01读取Transaction02未提交的修改。
②读已提交:READCOMMITTED
要求Transaction01只能读取Transaction02已提交的修改。
③可重复读:REPEATABLEREAD
确保Transaction01可以多次从一个字段中读取到相同的值,即Transaction01执行期间禁止其它事务对这个字段进行更新。
④串行化:SERIALIZABLE
确保Transaction01可以多次从一个表中读取到相同的行,在Transaction01执行期间,禁止其它事务对这个表进行添加、更新、删除操作。可以避免任何并发问题,但性能十分低下。
⑤各个隔离级别解决并发问题的能力见下表
脏读
不可重复读
幻读
READ UNCOMMITTED
有
有
有
READ COMMITTED
无
有
有
REPEATABLE READ
无
无
有
SERIALIZABLE
无
无
无
⑥各种数据库产品对事务隔离级别的支持程度
Oracle
MySQL
READ UNCOMMITTED
×
√
READ COMMITTED
√
√
REPEATABLE READ
×
√(默认)
SERIALIZABLE
√
√
可以在@Transactional的isolation属性中设置隔离级别
三、事务根据什么异常不进行回滚
1.默认情况
捕获到RuntimeException或Error时回滚,而捕获到编译时异常不回滚。
2.设置途经
注解
@Transactional注解
[1]rollbackFor属性:指定遇到时必须进行回滚的异常类型,可以为多个
[2]noRollbackFor属性:指定遇到时不回滚的异常类型,可以为多个
四、事务的超时属性
超时事务属性:事务在强制回滚之前可以保持多久。这样可以防止长期运行的事务占用资源。时间是指SQL语言的执行时间,而不是整个方法的执行时间。
五、事务的只读属性
- Spring中声明式事务的注解@Transactional的参数的总结(REQUIRED和REQUIRES_NEW的与主方法的回滚问题)
- 事务 @Transactional 的 Propagation.REQUIRES_NEW
- 关于Spring的@Transactional注解失效以及事务无法回滚问题
- spring的事务NEST与REQUIRES_NEW区别
- spring的事务注解@Transactional
- Spring 声明式事务中使用注解@Transactional的方式、原理及注意事项
- spring事务配置,声明式事务管理和基于@Transactional注解的使用
- spring事务配置,声明式事务管理和基于@Transactional注解的使用
- Spring事务配置,声明式事务管理和基于@Transactional注解的使用
- Spring中Transactional不添加rollbackFor等属性时的事务回滚问题
- Spring MVC @Transactional注解方式事务无法回滚的解决办法
- spring丶基于@Transactional注解的事务配置,声明式事务管理的使用
- [spring,mysql] spring使用注解式事务声明(@Transactional)无法回滚
- 基于@Transactional注解的Spring事务
- spring 事务REQUIRES_NEW 不起作用的解决方法
- spring 事务REQUIRES_NEW 不起作用的解决方法
- spring 事务Propagation.REQUIRES_NEW 不起作用的原因
- spring 事务REQUIRES_NEW 不起作用的解决方法
- 图片加载库-Glide
- WebStorm设置Ctrl+滚轮调整字体大小
- qtabwidget表头字体大小、字体颜色、背景颜色设置
- JAVA互联网架构学习之JdbcTemplate
- EF架构~mysql数据库无法创建数据模型
- Spring中声明式事务的注解@Transactional的参数的总结(REQUIRED和REQUIRES_NEW的与主方法的回滚问题)
- bintray-release使用指南(一)
- Leetcode-350
- log4j日志分模块打印
- altera 的EPM3256A EPM3256AQC208 芯片烧录 量产烧录工具 烧录器 烧录问题解决
- Java之类与对象的概念简介
- bintray-release配置publish闭包(二)
- 大陆身份证号码格式校验代码
- 基于GAN的mnist训练集图片生成神经网络实现