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:以非事务方式执行,如果当前有事务,就抛出异常。这个级别用于完全不需要事务支持的情况。


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

相关推荐
枫叶丹47 分钟前
破局政务数字化核心难题:金仓数据库以国产化方案引领电子证照系统升级之路
数据库·政务·1024程序员节·金仓
托比-马奎尔10 分钟前
Redis主从集群
数据库·redis·缓存
码力引擎1 小时前
【零基础学MySQL】第一章:MySQL介绍与安装
数据库·mysql·1024程序员节
Sam_Deep_Thinking1 小时前
MySQL 8 索引与 B+ 树-初浅理解
mysql
235161 小时前
【MySQL】慢查寻的发现和解决优化(思维导图版)
java·后端·sql·mysql·职场和发展·数据库开发·数据库架构
小超嵌入式笔记1 小时前
【Keil5教程及技巧】耗时一周精心整理万字全网最全Keil5(MDK-ARM)功能详细介绍【建议收藏-细细品尝】
java·数据库·mongodb
hweiyu002 小时前
Node.js+Koa2+MySQL 打造前后端分离项目(视频教程)
数据库·mysql·node.js
isNotNullX3 小时前
一文讲清:数据清洗、数据中台、数据仓库、数据治理
大数据·网络·数据库·数据分析·1024程序员节
penguin_bark3 小时前
C++调用MySQL数据库完整教程
数据库·c++·mysql
曾凡宇先生3 小时前
无法远程连接 MySQL
android·开发语言·数据库·sql·tcp/ip·mysql·adb