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 小时前
记一次基于QT的图片操作处理优化思路(包括在图上放大缩小,截图,画线,取值等)
开发语言·数据库·qt
奇树谦3 小时前
Qt | 利用map创建多个线程和定时器
网络·数据库·qt
用户47949283569153 小时前
性能提升 4000%!我是如何解决 运营看板 不能跨库&跨库查询慢这个难题的
数据库·后端·postgresql
电商API&Tina3 小时前
跨境电商 API 对接指南:亚马逊 + 速卖通接口调用全流程
大数据·服务器·数据库·python·算法·json·图搜索算法
robinson19883 小时前
验证崖山数据库标量子查询是否带有CACHE功能
数据库·oracle·cache·自定义函数·崖山·标量子查询
老华带你飞3 小时前
农产品销售管理|基于java + vue农产品销售管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
SelectDB4 小时前
5 倍性能提升,Apache Doris TopN 全局优化详解|Deep Dive
数据库·apache
JIngJaneIL4 小时前
基于springboot + vue房屋租赁管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
陈平安安5 小时前
设计一个秒杀功能
java·数据库·sql
isNotNullX5 小时前
数据处理的流程是什么?如何进行数据预处理?
数据库·数据资产管理·数据处理·企业数字化