Heim >Backend-Entwicklung >PHP-Tutorial >Zwei Lösungen zur Implementierung von MySQL-verschachtelten Transaktionen in PHP
1. Ursprung des Problems
In der offiziellen Dokumentation von MySQL gibt es eine klare Aussage, dass verschachtelte Transaktionen nicht unterstützt werden:
1. Transaktionen können nicht verschachtelt werden, wenn Sie eine START TRANSACTION-Anweisung oder eines ihrer Synonyme ausgeben
Aber wenn wir ein komplexes System entwickeln, ist es unvermeidlich, dass wir versehentlich Transaktionen in Transaktionen einbetten. Beispielsweise ruft Funktion A Funktion B auf, Funktion A verwendet eine Transaktion und Funktion B wird in der Transaktion aufgerufen Da es sich ebenfalls um eine Transaktion handelt, kommt es zu einer Transaktionsverschachtelung. Zu diesem Zeitpunkt sind die Angelegenheiten von A eigentlich von geringer Bedeutung. Es wird im obigen Dokument erwähnt und die einfache Übersetzung lautet:1. Bei der Ausführung einer START TRANSACTION-Anweisung wird implizit eine Commit-Operation ausgeführt. Daher müssen wir die Verschachtelung von Transaktionen auf der Ebene der Systemarchitektur unterstützen.
Glücklicherweise unterstützen einige ausgereifte ORM-Frameworks die Verschachtelung, beispielsweise Doctrine oder Laravel. Schauen wir uns als Nächstes an, wie diese beiden Frameworks implementiert werden. Zur Erinnerung: Die Benennung von Funktionen und Variablen in diesen beiden Frameworks ist relativ intuitiv, obwohl sie sehr langwierig aussieht. Sie können die Bedeutung der Funktion oder Variablen jedoch direkt durch die Benennung erkennen, sodass auf den ersten Blick kein so großes Durcheinander entsteht. Ich war schockiert :)
2. Lösung der Lehre
Werfen wir zunächst einen Blick auf den Code zum Erstellen einer Transaktion in Doctrine (irrelevanter Code entfernt):
[php] Klartext anzeigen
[php] Klartext anzeigen
可以看到处理的方式也很简单, 如果level是1, 直接rollback, 否则就回滚到前面的savepoint.然后我们继续看下commit函数:
[php] Klartext anzeigen
算了,不费口舌解释这段了吧 :)
三、laravel的解决方案laravel的处理方式相对简单粗暴一些,我们先来看下创建事务的操作:
[php] Klartext anzeigen
So einfach么为啥是啥都不做呢?继续往下看rollBack的操作:
[php] Klartext anzeigen
明白了吧?只有当当前事务只有一个的时候才会真正的rollback,否则只是将计数做减一操作.这也就是为啥刚才说laravel的处理比较简单粗暴一些, 在嵌套的内层里面实际上是木有真正的事务的,只有最外层一个整体的事务,虽然简单粗暴,但是也解决了在内层新建一个事务时会造成commit的问题.原理就是这个样子了,为了保持完整起见,把commit的代码也copy过来吧!
[php] Klartext anzeigen
以上就介绍了PHP中实现MySQL嵌套事务的两种解决方案, 包括了方面的内容, 希望对PHP教程有兴趣的朋友有所帮助.