前言
我们在开发一个复杂的系统时可能经常出现这样的场景:比如,A函数中调用了B函数,而A函数和B函数同时都使用了事务,这样就出现了事务嵌套。在MySQL的官方文档中有明确的说明MySQL是不支持嵌套事务的:
Transactions cannot be nested. This is a consequence of the implicit commit performed for any current transaction when you issue a START TRANSACTION statement or one of its synonyms.
那我们该如何解决MySQL的事务嵌套问题呢?
解决方法
目前,在PHP圈有两种比较通用的解决方法,一种是以Doctrine为代表的,设置回滚点的解决方法,一种是以Laravel为代表的,控制事务次数的解决方法。
Doctrine的解决方法
Doctrine解决方法的核心就是对回滚点的控制,如下:
<