2022
我们一起努力

MySQL数据库中怎么实现事务嵌套 - 数据库

本篇文章为大家展示了MySQL数据库中怎么实现事务嵌套,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

解决方法

目前,在PHP圈有两种比较通用的解决方法,一种是以Doctrine为代表的,设置回滚点的解决方法,一种是以Laravel为代表的,控制事务次数的解决方法。

Doctrine的解决方法

Doctrine解决方法的核心就是对回滚点的控制,如下:

Doctrine中开启事务的方法

Doctrine中事务回滚的方法

Doctrine中事务提交的方法

MySQL数据库中怎么实现事务嵌套 - 数据库

Doctrine用一个_transactionNestingLevel来标识当前嵌套的级别,如果是1,也就是还没有嵌套,那就用默认的方法执行一下START TRANSACTION就ok了;如果大于1,也就是有嵌套的时候,它会帮我们创建一个savepoint。这个savepoint可以理解为一个事务记录点,当需要回滚时我们可以只回滚到这个点。

Laravel的解决方法

相对Doctrine而言,Laravel的解决方法稍微简单粗暴,它巧妙的使用了一个 transactions属性来记录了调用事务的次数。在事务开启,事务提交和事务回滚时,先判断transactions的属性值,只有当transactions的属性值为1时,才进行事务操作。如下:

在开启事务时,我们先判断当前有几个事务,如果是***个,ok,事务开始,否则就啥都不做。

在事务提交时,也判断当前事务个数,如果是***个,ok,提交事务,否则,就只将transactions属性值减一

在事务回滚时,同样先判断当前事务个数,如果是***个,ok,回滚事务,同时将transactions属性值置为0,否则,就只将transactions属性值减一。

在Laravel的解决方法中,在嵌套的内层里面实际上是木有真正的事务的,只有最外层一个整体的事务,虽然简单粗暴,但是也解决了在内层新建一个事务时会造成commit的问题。

上述内容就是MySQL数据库中怎么实现事务嵌套,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注云行业资讯频道。

赞(0)
文章名称:《MySQL数据库中怎么实现事务嵌套 - 数据库》
文章链接:https://www.fzvps.com/98889.html
本站文章来源于互联网,如有侵权,请联系管理删除,本站资源仅供个人学习交流,请于下载后24小时内删除,不允许用于商业用途,否则法律问题自行承担。
图片版权归属各自创作者所有,图片水印出于防止被无耻之徒盗取劳动成果的目的。

评论 抢沙发

评论前必须登录!