溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

MySQL數(shù)據(jù)庫中怎么實現(xiàn)事務(wù)嵌套

發(fā)布時間:2021-07-13 16:00:24 來源:億速云 閱讀:212 作者:Leah 欄目:數(shù)據(jù)庫

本篇文章為大家展示了MySQL數(shù)據(jù)庫中怎么實現(xiàn)事務(wù)嵌套,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

解決方法

目前,在PHP圈有兩種比較通用的解決方法,一種是以Doctrine為代表的,設(shè)置回滾點的解決方法,一種是以Laravel為代表的,控制事務(wù)次數(shù)的解決方法。

Doctrine的解決方法

Doctrine解決方法的核心就是對回滾點的控制,如下:

MySQL數(shù)據(jù)庫中怎么實現(xiàn)事務(wù)嵌套

Doctrine中開啟事務(wù)的方法

MySQL數(shù)據(jù)庫中怎么實現(xiàn)事務(wù)嵌套

Doctrine中事務(wù)回滾的方法

MySQL數(shù)據(jù)庫中怎么實現(xiàn)事務(wù)嵌套

Doctrine中事務(wù)提交的方法

Doctrine用一個_transactionNestingLevel來標(biāo)識當(dāng)前嵌套的級別,如果是1,也就是還沒有嵌套,那就用默認(rèn)的方法執(zhí)行一下START TRANSACTION就ok了;如果大于1,也就是有嵌套的時候,它會幫我們創(chuàng)建一個savepoint。這個savepoint可以理解為一個事務(wù)記錄點,當(dāng)需要回滾時我們可以只回滾到這個點。

Laravel的解決方法

相對Doctrine而言,Laravel的解決方法稍微簡單粗暴,它巧妙的使用了一個 transactions屬性來記錄了調(diào)用事務(wù)的次數(shù)。在事務(wù)開啟,事務(wù)提交和事務(wù)回滾時,先判斷transactions的屬性值,只有當(dāng)transactions的屬性值為1時,才進(jìn)行事務(wù)操作。如下:

MySQL數(shù)據(jù)庫中怎么實現(xiàn)事務(wù)嵌套

在開啟事務(wù)時,我們先判斷當(dāng)前有幾個事務(wù),如果是***個,ok,事務(wù)開始,否則就啥都不做。

MySQL數(shù)據(jù)庫中怎么實現(xiàn)事務(wù)嵌套

在事務(wù)提交時,也判斷當(dāng)前事務(wù)個數(shù),如果是***個,ok,提交事務(wù),否則,就只將transactions屬性值減一

MySQL數(shù)據(jù)庫中怎么實現(xiàn)事務(wù)嵌套

在事務(wù)回滾時,同樣先判斷當(dāng)前事務(wù)個數(shù),如果是***個,ok,回滾事務(wù),同時將transactions屬性值置為0,否則,就只將transactions屬性值減一。

在Laravel的解決方法中,在嵌套的內(nèi)層里面實際上是木有真正的事務(wù)的,只有最外層一個整體的事務(wù),雖然簡單粗暴,但是也解決了在內(nèi)層新建一個事務(wù)時會造成commit的問題。

上述內(nèi)容就是MySQL數(shù)據(jù)庫中怎么實現(xiàn)事務(wù)嵌套,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI