91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

MySQL數據庫中怎么實現事務嵌套

發布時間:2021-07-13 16:00:24 來源:億速云 閱讀:213 作者:Leah 欄目:數據庫

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

解決方法

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

Doctrine的解決方法

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

MySQL數據庫中怎么實現事務嵌套

Doctrine中開啟事務的方法

MySQL數據庫中怎么實現事務嵌套

Doctrine中事務回滾的方法

MySQL數據庫中怎么實現事務嵌套

Doctrine中事務提交的方法

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

Laravel的解決方法

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

MySQL數據庫中怎么實現事務嵌套

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

MySQL數據庫中怎么實現事務嵌套

在事務提交時,也判斷當前事務個數,如果是***個,ok,提交事務,否則,就只將transactions屬性值減一

MySQL數據庫中怎么實現事務嵌套

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

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

上述內容就是MySQL數據庫中怎么實現事務嵌套,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

蛟河市| 临江市| 松滋市| 敦煌市| 桐梓县| 遂溪县| 明溪县| 瑞金市| 综艺| 荆州市| 盖州市| 乡城县| 涟水县| 搜索| 景德镇市| 威宁| 平阳县| 达州市| 达日县| 凌源市| 仪征市| 扬州市| 武强县| 山阴县| 泾川县| 兴义市| 安福县| 开原市| 肥乡县| 花莲市| 南雄市| 金坛市| 陕西省| 南乐县| 寻甸| 阜阳市| 海原县| 石狮市| 玛多县| 凌海市| 龙门县|