Mysql的事务传播机制

现在假设有两个方法,分别是A方法、B方法,B方法运行在A方法中。

  • PROPAGATION_REQUIRED:表示当前方法必须运行在事务中。如果A事务存在,B事务就会融入A事务。否则,会启动一个新的事务。REQUIRED就是需要,意思就是B事务无论如何要有事务。

  • PROPAGATION_SUPPORTS:表示当前方法不需要事务上下文,但是如果A事务存在的话,B事务就会融入A事务,否则不开启事务执行。SUPPORTS表示支持,就是B事务会支持A事务。

  • PROPAGATION_MANDATORY:(强制性的)表示该方法必须在事务中运行,如果A事务不存在,则会抛出一个异常。

  • PROPAGATION_REQUIRES_NEW:(需要个新的)表示当前方法必须运行在它自己的事务中。一个新的事务将被启动。如果存在A事务,在该方法执行期间,A事务会被挂起,否则会给B开启一个新事务。

  • PROPAGATION_NOT_SUPPORTED:(不支持事务)表示该方法不应该运行在事务中。如果存在A事务,在该方法运行期间,B事务将被挂起,以非事务的方式运行。

  • PROPAGATION_NEVER:(不会运行在有事务的环境)表示当前方法不应该运行在事务上下文中。如果当前正有一个事务在运行,则会抛出异常。和PROPAGATION_MANDATORY相反

  • PROPAGATION_NESTED:(嵌套的)表示如果当前已经存在一个事务,那么该方法将会在嵌套事务中运行。嵌套的事务可以独立于当前事务进行单独地提交或回滚。如果当前事务不存在,那么其行为与REQUIRED一样。注意各厂商对这种传播行为的支持是有所差异的。可以参考资源管理器的文档来确认它们是否支持嵌套事务。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值