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


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

相关推荐
2401_83595681几秒前
Golang怎么安全关闭channel_Golang channel关闭教程【通俗】
jvm·数据库·python
Absurd5875 分钟前
golang如何实现MQTT主题通配符路由_golang MQTT主题通配符路由实现策略
jvm·数据库·python
m0_674294645 分钟前
宝塔面板如何设置网站强制HTTPS_配置Nginx自动跳转规则
jvm·数据库·python
qq_424098566 分钟前
HTML函数开发用可拆卸键盘设计实用吗_模块化硬件体验评估【指南】
jvm·数据库·python
Wyz201210246 分钟前
CSS如何实现Less颜色函数自动计算渐变_使用lighten与darken实现视觉反馈
jvm·数据库·python
weixin_458580127 分钟前
CSS如何通过Emotion管理样式加载顺序_处理组件优先级问题
jvm·数据库·python
qq_334563558 分钟前
golang如何优化GORM查询性能_golang GORM查询性能优化方法
jvm·数据库·python
weixin_424999369 分钟前
CSS如何处理移动端弹窗背景滚动_使用JS控制配合CSS样式锁定
jvm·数据库·python
y = xⁿ9 分钟前
MySQL:事务机制
数据库·mysql
m0_5150984211 分钟前
golang如何实现日志按级别过滤_golang日志按级别过滤实现教程
jvm·数据库·python