Spring支持的常用数据库事务传播属性和事务隔离级别?
事务传播属性
事务的传播行为:一个方法运行在了一个开启了事务的方法中时,当前方法是使用原来的事务还是开启一个新的事务
事务的传播行为可以由传播属性指定。Spring定义了7种类传播行为。
传播属性 | 描述 |
REQUIRED(常用) |
如果有事务在运行,当前的方法就在这个事务内运行,否则,就启动一个新的事务,并在自己的事务内运行 |
REQUIRED_NEW(常用) |
当前的方法必须启动新事务,并在它自己的事务内运行.如果有事务正在运行,应该将它挂起 |
SUPPORTS |
如果有事务在运行,当前的方法就在这个事务内运行.否则它可以不运行在事务中 |
NOT_SUPPORTED |
当前的方法不应该运行在事务中.如果有运行的事务,将它挂起 |
MANDATORY |
当前的方法必须运行在事务内部,如果没有正在运行的事务,就抛出异常 |
NEVER |
当前的方法不应该运行在事务中.如果有运行的事务,就抛出异常 |
NESTED |
如果有事务在运行,当前的方法就应该在这个事务的嵌套事务内运行.否则,就启动一-个新的事务,并在它自己的事务内运行 |
事务传播属性可以在@Transactional注解的propagation属性中定义。
事务隔离级别
数据库事务并发问题
假设现在有两个事务:Transaction01和 Transaction02并发执行。
1、脏读
①Transaction01将某条记录的AGE值从20修改为30。
②Transaction02读取了Transaction01更新后的值:30。
③Transaction01回滚,AGE值恢复到了20。
④Transaction02读取到的30就是一个无效的值。
2、不可重复读
①Transaction01读取了AGE值为20。
②Transaction02将AGE值修改为30。
③Transaction01再次读取AGE值为30,和第一次读取不一致。
3、幻读
①Transaction01读取了STUDENT表中的一部分数据。
②Transaction02向STUDENT表中插入了新的行。
③Transaction01读取STUDENT表时,多出了一些行。
隔离级别
数据库系统必须具有隔离并发运行各个事务的能力,使它们不会相互影响,避免各种并发问题。一个事务与其他事务隔离的程度称为隔离级别。SQL标准中规定了多种事务隔离级别,不同隔离级别对应不同的干扰程度﹐隔离级别越高,数据一致性就越好,但并发性越弱。
①读未提交:READ UNCOMMITTED
允许Transaction01读取Transaction02未提交的修改。
②读已提交:READ COMMITTEDJ(开发时通常使用的隔离级别)
要求Transaction01只能读取Transaction02己提交的修改。
③可重复读:REPEATABLE READ
确保Transaction01可以多次从一个字段中读取到相同的值,即 Transaction01执行期间禁止其它事务对这个字段进行更新。
④串行化:SERIALIZABLE
确保Transaction01可以多次从一个表中读取到相同的行,在Transaction01执行期间,禁止其它事务对这个表进行添加、更新、删除操作。可以避免任何并发问题,但性能十分低下。
解决能力
脏读 | 不可重复读 | 幻读 | |
READ UNCOMMITTED |
有 | 有 | 有 |
READ COMMITTED |
无 | 有 | 有 |
REPEATABLE READ |
无 | 无 | 有 |
SERIALIZABLE |
无 | 无 | 无 |
支持程度
Oralce | MySQL | |
READ UNCOMMITTED | ✗ | ✓ |
READ COMMITTED | ✓(默认) | ✓ |
REPEATABLE READ | ✗ | ✓(默认) |
SERIALIZABLE | ✓ | ✓ |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?