Spring事务传播机制

什么是事务?

  • 什么是事务
    • 事务:逻辑上是多个写sql组成的操作,组成这组操作的各个单元,要么全部成功,要么全部失败.
  • 事物的特性
    • 原子性:事务不可分割
    • 一致性:事务执行前后数据完整性保持一致
    • 隔离性:一个事务的执行不应该受到其他事物的影响
    • 持久性:一旦事务结束,数据就持久化到数据库

mysql的隔离级别

  • Read uncommitted:读未提交,任何问题解决不了
  • Read committed:读已提交,解决脏读,但是不可重复度和幻读有可能发生(Oracle默认)
  • Repeatable read:重复度,解决脏读和不可重复读,但是幻读可能发生(msyql默认)
  • Serializable:序列化,解决所有读问题

在各个级别下会出现的问题

隔离级别问题解释常用语
读未提交A事务读取到B事务未提交的数据脏读
读已提交A事务使用同样的查询语句单结果集不通(数据内容)不可重复度
重复读(默认)A事务使用同样的查询语句但返回的结果集数量不同(数据数量)幻读
串行化没有数据问题(行锁+简希锁解决)

事务失效的十种情况

  • 使用java的private修饰符修饰的方法
  • 使用try-catch捕获异常
  • 使用jPROPAGATION_NOT_SUPPORTED以事务的方式提交
  • 使用新的线程执行方法,导致事务绑定失败
  • 使用rollbackFor = RuntimeException.class设置了回滚异常的类型,但抛出了Exception.class从而导致失效
  • 数据库引擎不支持事务
  • 没有启用事务管理器@EnableTransactionManagement
  • 没有开启事务注解@Transactional
  • 在静态方法上开起@Transactional
  • 没有将事务交给Spring管理,或者使用new初始化service对象

事务的7中传播机制

  • PROPAGATION_REQUIRED:默认值,如果A中有事务,使用A中的事务,如果A没有,创建一个新的事务,将操作包含进来
  • PROPAGATION_SUPPORTS : 支持事务,如果A中有事务,使用A中的事务。如果A没有事务,不使用事务。
  • PROPAGATION_MANDATORY :如果A中有事务,使用A中的事务。如果A没有事务,抛出异常。
  • PROPAGATION_REQUIRES_NEW :如果A中有事务,将A的事务挂起(暂停),创建新事务,只包含自身操作。如果A中没有事务,创建一个新事务,包含自身操作。
  • PROPAGATION_NOT_SUPPORTED :如果A中有事务,将A的事务挂起。不使用事务管理。
  • PROPAGATION_NEVER :如果A中有事务,报异常。
  • PROPAGATION_NESTED :嵌套事务,如果A中有事务,按照A的事务执行,执行完成后,设置一个保存点,执行B中的操作,如果没有异常,执行通过,如果有异常,可以选择回滚到最初始位置,也可以回滚到保存点。

gitee上面的事务传播机制以及测试用例,大家最好下载并跑跑代码加深记忆。毕竟我们不是为了学习而学习。单纯为了升职加薪而学习。

git地址

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

心有城府,腹有良谋

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值