成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

「MySQL數據庫」事務嵌套的解決之道

數據庫 MySQL 后端
A函數中調用了B函數,而A函數和B函數同時都使用了事務,這樣就出現了事務嵌套。在MySQL的官方文檔中有明確的說明MySQL是不支持嵌套事務的。

 前言

我們在開發一個復雜的系統時可能經常出現這樣的場景:比如,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解決方法的核心就是對回滾點的控制,如下:

Doctrine中開啟事務的方法

Doctrine中事務回滾的方法

Doctrine中事務提交的方法

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的問題。 

責任編輯:龐桂玉 來源: 今日頭條
相關推薦

2009-10-10 15:26:11

資產管理

2016-12-22 09:02:35

Linux誤刪文件

2021-03-28 21:33:07

Redis熱點key

2022-01-14 08:08:11

Java依賴沖突

2022-11-02 10:13:09

2012-02-26 16:26:42

IBM大數據Hadoop

2019-11-27 10:28:11

公共安全大數據數據聯系

2017-10-26 09:50:55

2009-05-05 14:30:19

虛擬化安全解決方案

2011-08-18 14:23:52

Big Data

2012-02-13 10:30:18

2012-06-05 19:18:43

BYODAvayaAvaya IDE

2014-09-29 16:44:12

2011-01-19 13:12:27

2016-11-10 18:57:19

雙十一高并發

2011-09-10 20:48:34

2022-04-21 09:26:41

FastDFS開源分布式文件系統

2012-09-05 17:45:03

存儲系統大數據華為

2011-02-02 16:18:39

2011-11-08 10:11:34

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品久久一区 | 18gay男同69亚洲网站 | 亚洲精品视频在线播放 | 欧美一区二区大片 | 亚洲一区二区av | 久久久久国产一区二区三区四区 | 日韩av在线一区二区 | 日日夜夜精品免费视频 | 国产在线视频三区 | 中文字幕日本一区二区 | 欧美精品一区二区三区在线播放 | 91在线成人 | 综合色站导航 | www.天天操.com | 国产激情一区二区三区 | 综合婷婷 | 久色网 | 国产激情一区二区三区 | 精品国产高清一区二区三区 | 精品在线播放 | 综合激情久久 | 狠狠的日 | 国产精品久久久 | 久久久久国产精品免费免费搜索 | 日韩有码一区 | 午夜精品久久久久久久久久久久久 | 成人午夜在线 | 美女福利视频网站 | 国产欧美一区二区三区日本久久久 | 中国大陆高清aⅴ毛片 | a视频在线播放 | 狠狠的操 | 精品免费视频 | 午夜影视免费片在线观看 | 91在线看网站 | www.久久久久久久久久久 | 日本久久久一区二区三区 | 国产激情在线观看 | 97伊人| 91免费在线视频 | 911精品美国片911久久久 |