偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

「MySQL數(shù)據(jù)庫」事務(wù)嵌套的解決之道

數(shù)據(jù)庫 MySQL 后端
A函數(shù)中調(diào)用了B函數(shù),而A函數(shù)和B函數(shù)同時(shí)都使用了事務(wù),這樣就出現(xiàn)了事務(wù)嵌套。在MySQL的官方文檔中有明確的說明MySQL是不支持嵌套事務(wù)的。

 前言

我們?cè)陂_發(fā)一個(gè)復(fù)雜的系統(tǒng)時(shí)可能經(jīng)常出現(xiàn)這樣的場景:比如,A函數(shù)中調(diào)用了B函數(shù),而A函數(shù)和B函數(shù)同時(shí)都使用了事務(wù),這樣就出現(xiàn)了事務(wù)嵌套。在MySQL的官方文檔中有明確的說明MySQL是不支持嵌套事務(wù)的:

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.

那我們?cè)撊绾谓鉀QMySQL的事務(wù)嵌套問題呢?

解決方法

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

Doctrine的解決方法

Doctrine解決方法的核心就是對(duì)回滾點(diǎn)的控制,如下:

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

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

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

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

Laravel的解決方法

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

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

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

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

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

責(zé)任編輯:龐桂玉 來源: 今日頭條
相關(guān)推薦

2009-10-10 15:26:11

資產(chǎn)管理

2016-12-22 09:02:35

Linux誤刪文件

2021-03-28 21:33:07

Redis熱點(diǎn)key

2022-01-14 08:08:11

Java依賴沖突

2022-11-02 10:13:09

2012-02-26 16:26:42

IBM大數(shù)據(jù)Hadoop

2017-10-26 09:50:55

2019-11-27 10:28:11

公共安全大數(shù)據(jù)數(shù)據(jù)聯(lián)系

2011-01-19 13:12:27

2009-05-05 14:30:19

虛擬化安全解決方案

2012-06-05 19:18:43

BYODAvayaAvaya IDE

2011-08-18 14:23:52

Big Data

2012-02-13 10:30:18

2014-09-29 16:44:12

2016-11-10 18:57:19

雙十一高并發(fā)

2022-04-21 09:26:41

FastDFS開源分布式文件系統(tǒng)

2011-09-10 20:48:34

2012-09-05 17:45:03

存儲(chǔ)系統(tǒng)大數(shù)據(jù)華為

2021-05-13 16:49:36

區(qū)塊鏈技術(shù)應(yīng)用

2011-11-08 10:11:34

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)