MySQL — 事务的传播级别有什么作用?有哪些事务的传播级别?

置顶

学习专栏:【Java后端面试题】


事务的传播级别有什么作用?

  • 事务的 传播级别 定义了在 多个事务交互 时,事务 如何进行 协作和处理
  • 传播级别 用于控制 事务的范围和行为,确保 多个事务并发执行 时能够达到 预期的结果。不同的传播级别适用于不同的应用场景和需求。

有哪些事务的传播级别?

  1. PROPAGATION_REQUIRED(默认级别):如果当前没有事务,就创建一个新的事务;如果已经存在一个事务,就加入到当前事务中。这是最常用的传播级别,确保了一组操作要么全部成功,要么全部回滚,保持了一致性。

  2. PROPAGATION_REQUIRES_NEW:创建一个新的事务,如果当前已经存在一个事务,就将当前事务挂起。这个级别用于需要独立的子事务,子事务不会受到外部事务的影响,可以独立提交或回滚。

  3. PROPAGATION_NESTED:创建一个嵌套事务,如果当前已经存在一个事务,则在嵌套事务内部创建一个子事务。嵌套事务可以独立提交或回滚,但只有在主事务提交时才会被永久保存。这个级别用于需要在主事务内部管理子事务的情况。

  4. PROPAGATION_SUPPORTS:如果当前有事务,就加入到当前事务中;如果当前没有事务,就以非事务方式执行。这个级别用于在一定程度上支持事务,但不会强制执行事务。

  5. PROPAGATION_NOT_SUPPORTED:以非事务方式执行,如果当前有事务,就将其挂起。这个级别用于需要明确不支持事务的情况。

  6. PROPAGATION_MANDATORY:如果当前有事务,就加入到当前事务中;如果当前没有事务,就抛出异常。这个级别用于需要强制要求事务存在的情况。

  7. PROPAGATION_NEVER:以非事务方式执行,如果当前有事务,就抛出异常。这个级别用于需要明确禁止事务的情况。

  8. PROPAGATION_NONE:以非事务方式执行,如果当前有事务,就抛出异常。这个级别用于完全不需要事务支持的情况。


------ 感谢观看,一键三连 ------

相关推荐
睡觉的时候不会困1 分钟前
Redis 主从复制详解:原理、配置与主从切换实战
数据库·redis·bootstrap
程序员的世界你不懂2 小时前
【Flask】测试平台开发,新增说明书编写和展示功能 第二十三篇
java·前端·数据库
自学也学好编程2 小时前
【数据库】Redis详解:内存数据库与缓存之王
数据库·redis
福赖2 小时前
《MySQL基础——用户管理》
mysql·用户管理
JAVA不会写2 小时前
在Mybatis plus中如何使用自定义Sql
数据库·sql
IT 小阿姨(数据库)3 小时前
PgSQL监控死元组和自动清理状态的SQL语句执行报错ERROR: division by zero原因分析和解决方法
linux·运维·数据库·sql·postgresql·centos
ChinaRainbowSea3 小时前
7. LangChain4j + 记忆缓存详细说明
java·数据库·redis·后端·缓存·langchain·ai编程
小马学嵌入式~4 小时前
嵌入式 SQLite 数据库开发笔记
linux·c语言·数据库·笔记·sql·学习·sqlite
Java小白程序员4 小时前
MyBatis基础到高级实践:全方位指南(中)
数据库·mybatis
Monly214 小时前
人大金仓:merge sql error, dbType null, druid-1.2.20
数据库·sql