免费爱碰视频在线观看,九九精品国产屋,欧美亚洲尤物久久精品,1024在线观看视频亚洲

      MySQL 事務(wù)的默認(rèn)隔離級別是什么?可以解決幻讀問題么?

      何謂事務(wù)?

      我們設(shè)想一個場景,這個場景中我們需要插入多條相關(guān)聯(lián)的數(shù)據(jù)數(shù)據(jù)庫,不幸的是,這個過程可能會遇到下面這些問題:

      • 數(shù)據(jù)庫中途突然因為某些原因掛掉了。
      • 客戶端突然因為網(wǎng)絡(luò)原因連接不上數(shù)據(jù)庫了。
      • 并發(fā)訪問數(shù)據(jù)庫時,多個線程同時寫入數(shù)據(jù)庫,覆蓋了彼此的更改。
      • ……

      上面的任何一個問題都可能會導(dǎo)致數(shù)據(jù)的不一致性。為了保證數(shù)據(jù)的一致性,系統(tǒng)必須能夠處理這些問題。事務(wù)就是我們抽象出來簡化這些問題的首選機制。事務(wù)的概念起源于數(shù)據(jù)庫,目前,已經(jīng)成為一個比較廣泛的概念。

      何為事務(wù)? 一言蔽之,事務(wù)是邏輯上的一組操作,要么都執(zhí)行,要么都不執(zhí)行。

      事務(wù)最經(jīng)典也經(jīng)常被拿出來說例子就是轉(zhuǎn)賬了。假如小明要給小紅轉(zhuǎn)賬 1000 元,這個轉(zhuǎn)賬會涉及到兩個關(guān)鍵操作,這兩個操作必須都成功或者都失敗。

    1. 將小明的余額減少 1000 元
    2. 將小紅的余額增加 1000 元。
    3. 事務(wù)會把這兩個操作就可以看成邏輯上的一個整體,這個整體包含的操作要么都成功,要么都要失敗。這樣就不會出現(xiàn)小明余額減少而小紅的余額卻并沒有增加的情況。

      何謂數(shù)據(jù)庫事務(wù)?

      大多數(shù)情況下,我們在談?wù)撌聞?wù)的時候,如果沒有特指分布式事務(wù),往往指的就是數(shù)據(jù)庫事務(wù)。

      數(shù)據(jù)庫事務(wù)在我們?nèi)粘i_發(fā)中接觸的最多了。如果你的項目屬于單體架構(gòu)的話,你接觸到的往往就是數(shù)據(jù)庫事務(wù)了。

      那數(shù)據(jù)庫事務(wù)有什么作用呢?

      簡單來說,數(shù)據(jù)庫事務(wù)可以保證多個對數(shù)據(jù)庫的操作(也就是 SQL 語句)構(gòu)成一個邏輯上的整體。構(gòu)成這個邏輯上的整體的這些數(shù)據(jù)庫操作遵循:要么全部執(zhí)行成功,要么全部不執(zhí)行 。

      # 開啟一個事務(wù)START TRANSACTION;# 多條 SQL 語句SQL1,SQL2…## 提交事務(wù)COMMIT;

      另外,關(guān)系型數(shù)據(jù)庫(例如:MySQL、SQL Server、Oracle 等)事務(wù)都有 ACID 特性:

      ACID

    4. 原子性(Atomicity) :事務(wù)是最小的執(zhí)行單位,不允許分割。事務(wù)的原子性確保動作要么全部完成,要么完全不起作用;
    5. 一致性(Consistency):執(zhí)行事務(wù)前后,數(shù)據(jù)保持一致,例如轉(zhuǎn)賬業(yè)務(wù)中,無論事務(wù)是否成功,轉(zhuǎn)賬者和收款人的總額應(yīng)該是不變的;
    6. 隔離性(Isolation):并發(fā)訪問數(shù)據(jù)庫時,一個用戶的事務(wù)不被其他事務(wù)所干擾,各并發(fā)事務(wù)之間數(shù)據(jù)庫是獨立的;
    7. 持久性(Durabilily):一個事務(wù)被提交之后。它對數(shù)據(jù)庫中數(shù)據(jù)的改變是持久的,即使數(shù)據(jù)庫發(fā)生故障也不應(yīng)該對其有任何影響。
    8. 這里要額外補充一點:只有保證了事務(wù)的持久性、原子性、隔離性之后,一致性才能得到保障。也就是說 A、I、D 是手段,C 是目的!

      并發(fā)事務(wù)帶來了哪些問題?

      在典型的應(yīng)用程序中,多個事務(wù)并發(fā)運行,經(jīng)常會操作相同的數(shù)據(jù)來完成各自的任務(wù)(多個用戶對同一數(shù)據(jù)進(jìn)行操作)。并發(fā)雖然是必須的,但可能會導(dǎo)致以下的問題。

      • 臟讀(Dirty read): 當(dāng)一個事務(wù)正在訪問數(shù)據(jù)并且對數(shù)據(jù)進(jìn)行了修改,而這種修改還沒有提交到數(shù)據(jù)庫中,這時另外一個事務(wù)也訪問了這個數(shù)據(jù),然后使用了這個數(shù)據(jù)。因為這個數(shù)據(jù)是還沒有提交的數(shù)據(jù),那么另外一個事務(wù)讀到的這個數(shù)據(jù)是“臟數(shù)據(jù)”,依據(jù)“臟數(shù)據(jù)”所做的操作可能是不正確的。
      • 丟失修改(Lost to modify): 指在一個事務(wù)讀取一個數(shù)據(jù)時,另外一個事務(wù)也訪問了該數(shù)據(jù),那么在第一個事務(wù)中修改了這個數(shù)據(jù)后,第二個事務(wù)也修改了這個數(shù)據(jù)。這樣第一個事務(wù)內(nèi)的修改結(jié)果就被丟失,因此稱為丟失修改。例如:事務(wù) 1 讀取某表中的數(shù)據(jù) A=20,事務(wù) 2 也讀取 A=20,事務(wù) 1 修改 A=A-1,事務(wù) 2 也修改 A=A-1,最終結(jié)果 A=19,事務(wù) 1 的修改被丟失。
      • 不可重復(fù)讀(Unrepeatable read): 指在一個事務(wù)內(nèi)多次讀同一數(shù)據(jù)。在這個事務(wù)還沒有結(jié)束時,另一個事務(wù)也訪問該數(shù)據(jù)。那么,在第一個事務(wù)中的兩次讀數(shù)據(jù)之間,由于第二個事務(wù)的修改導(dǎo)致第一個事務(wù)兩次讀取的數(shù)據(jù)可能不太一樣。這就發(fā)生了在一個事務(wù)內(nèi)兩次讀到的數(shù)據(jù)是不一樣的情況,因此稱為不可重復(fù)讀。
      • 幻讀(Phantom read): 幻讀與不可重復(fù)讀類似。它發(fā)生在一個事務(wù)(T1)讀取了幾行數(shù)據(jù),接著另一個并發(fā)事務(wù)(T2)插入了一些數(shù)據(jù)時。在隨后的查詢中,第一個事務(wù)(T1)就會發(fā)現(xiàn)多了一些原本不存在的記錄,就好像發(fā)生了幻覺一樣,所以稱為幻讀。

      不可重復(fù)讀和幻讀區(qū)別 :不可重復(fù)讀的重點是修改比如多次讀取一條記錄發(fā)現(xiàn)其中某些列的值被修改,幻讀的重點在于新增或者刪除比如多次查詢同一條查詢語句(DQL)時,記錄發(fā)現(xiàn)記錄增多或減少了。

      SQL 標(biāo)準(zhǔn)定義了哪些事務(wù)隔離級別?

      SQL 標(biāo)準(zhǔn)定義了四個隔離級別:

      • READ-UNCOMMITTED(讀取未提交) :最低的隔離級別,允許讀取尚未提交的數(shù)據(jù)變更,可能會導(dǎo)致臟讀、幻讀或不可重復(fù)讀。
      • READ-COMMITTED(讀取已提交) :允許讀取并發(fā)事務(wù)已經(jīng)提交的數(shù)據(jù),可以阻止臟讀,但是幻讀或不可重復(fù)讀仍有可能發(fā)生。
      • REPEATABLE-READ(可重復(fù)讀) :對同一字段的多次讀取結(jié)果都是一致的,除非數(shù)據(jù)是被本身事務(wù)自己所修改,可以阻止臟讀和不可重復(fù)讀,但幻讀仍有可能發(fā)生。
      • SERIALIZABLE(可串行化) :最高的隔離級別,完全服從 ACID 的隔離級別。所有的事務(wù)依次逐個執(zhí)行,這樣事務(wù)之間就完全不可能產(chǎn)生干擾,也就是說,該級別可以防止臟讀、不可重復(fù)讀以及幻讀。

      隔離級別臟讀不可重復(fù)讀幻讀READ-UNCOMMITTED READ-COMMITTED REPEATABLE-READ SERIALIZABLE

      MySQL 的隔離級別是基于鎖實現(xiàn)的嗎?

      MySQL 的隔離級別基于鎖和 MVCC 機制共同實現(xiàn)的。

      SERIALIZABLE 隔離級別,是通過鎖來實現(xiàn)的。除了 SERIALIZABLE 隔離級別,其他的隔離級別都是基于 MVCC 實現(xiàn)。

      不過, SERIALIZABLE 之外的其他隔離級別可能也需要用到鎖機制,就比如 REPEATABLE-READ 在當(dāng)前讀情況下需要使用加鎖讀來保證不會出現(xiàn)幻讀。

      MySQL 的默認(rèn)隔離級別是什么?

      MySQL InnoDB 存儲引擎的默認(rèn)支持的隔離級別是 REPEATABLE-READ(可重讀)。我們可以通過SELECT @@tx_isolation;命令來查看,MySQL 8.0 該命令改為SELECT @@transaction_isolation;

      mysql> SELECT @@tx_isolation;+—————–+| @@tx_isolation |+—————–+| REPEATABLE-READ |+—————–+

      從上面對 SQL 標(biāo)準(zhǔn)定義了四個隔離級別的介紹可以看出,標(biāo)準(zhǔn)的 SQL 隔離級別定義里,REPEATABLE-READ(可重復(fù)讀)是不可以防止幻讀的。

      但是!InnoDB 實現(xiàn)的 REPEATABLE-READ 隔離級別其實是可以解決幻讀問題發(fā)生的,主要有下面兩種情況:

      • 快照讀 :由 MVCC 機制來保證不出現(xiàn)幻讀。
      • 當(dāng)前讀 :使用 Next-Key Lock 進(jìn)行加鎖來保證不出現(xiàn)幻讀,Next-Key Lock 是行鎖(Record Lock)和間隙鎖(Gap Lock)的結(jié)合,行鎖只能鎖住已經(jīng)存在的行,為了避免插入新行,需要依賴間隙鎖。

      因為隔離級別越低,事務(wù)請求的鎖越少,所以大部分?jǐn)?shù)據(jù)庫系統(tǒng)的隔離級別都是 READ-COMMITTED ,但是你要知道的是 InnoDB 存儲引擎默認(rèn)使用 REPEATABLE-READ 并不會有任何性能損失。

      InnoDB 存儲引擎在分布式事務(wù)的情況下一般會用到 SERIALIZABLE 隔離級別。

      鄭重聲明:本文內(nèi)容及圖片均整理自互聯(lián)網(wǎng),不代表本站立場,版權(quán)歸原作者所有,如有侵權(quán)請聯(lián)系管理員(admin#wlmqw.com)刪除。
      (0)
      用戶投稿
      上一篇 2022年6月15日 12:38
      下一篇 2022年6月15日 12:38

      相關(guān)推薦

      • 鯊魚難言上演父子局,難言被擊倒在地,六蛋神操作不過如此

        和平精英作為一款深受各位玩家喜愛的游戲,不僅有著獨特的冒險模式,而且還能感受鋼槍的快樂。自這款游戲上線一來,就獲得了不少玩家的青睞。鯊魚作為這款游戲的知名主播,經(jīng)常在直播間中打出亮…

        2022年8月7日
      • 他34歲拿3年2010萬!同樣是湖人出來的中鋒,霍華德卻慘到?jīng)]人要

        NBA今年休賽期,大合同滿天飛,過2億的合同就不下好幾個,巨星們一個個賺得盆滿缽滿!巨星們拿那么多錢,角色球員肯定是和他們比不了!相對來說,他們能獲得一個不錯的合同,得到球隊的一個…

        2022年7月17日
      • IDC發(fā)布中國數(shù)字政府大數(shù)據(jù)市場份額報告 中國系統(tǒng)位居前列

        近日,全球權(quán)威IT市場研究和咨詢公司IDC發(fā)布《中國數(shù)字政府大數(shù)據(jù)管理平臺市場份額,2021》報告。中國系統(tǒng)憑借體系化“數(shù)智”創(chuàng)新產(chǎn)品和豐富的客戶實踐,位居中國數(shù)字政府大數(shù)據(jù)管理平…

        2022年8月19日
      • 6.Twisted UDP Socket 編程示例

        6.Twisted UDP Socket 編程示例 示例:客戶端每隔10秒向服務(wù)端報送設(shè)備使用情況,具體數(shù)據(jù)如下: 數(shù)據(jù) 說明 值示例 CPUUsed CPU占用情況 % 35.5…

        2022年7月1日
      • 如何看待元宇宙醫(yī)療五大場景爆發(fā)前夜

        黃巖/上海國創(chuàng)科技產(chǎn)業(yè)創(chuàng)新發(fā)展中心理事長 ·元宇宙虛擬世界與真實世界交互共生將經(jīng)歷三個發(fā)展階段:真實世界的仿真和數(shù)字化;全面數(shù)字孿生化;全行業(yè)全生命周期的元宇宙化。 ·元宇宙醫(yī)療是…

        2022年8月7日
      • 又現(xiàn)“內(nèi)斗”?這家公司總裁遭罷免

        陳俊、袁旭作為一致行為人聯(lián)手罷免前董事長章建偉后,迅游科技(300467)董事會內(nèi)斗并未平息,更在今年進(jìn)入“新一季”,本次對壘主角是上次內(nèi)斗的勝利者陳俊與袁旭。 6月2日晚間,迅游…

        2022年7月4日
      • 特斯拉中國銷量驟降超60%!電動車最新數(shù)據(jù)來了

        中國基金報見習(xí)記者 文夕 8月9日,乘聯(lián)會發(fā)布數(shù)據(jù),雖然7月新能源乘用車因淡季因素影響,零售銷量48.6萬輛環(huán)比下降8.5%,但7月的新能源乘用車廠商批發(fā)銷量56.4萬輛,跟去年增…

        2022年8月10日
      • 公積金貸款被拒怎么回事 從這些中找答案

        很多人以為提交了公積金貸款申請,就能成功買房,最后卻被告知審批不通過。個人征信良好卻貸款被拒,這讓他們很不解,那么公積金貸款被拒怎么回事?一起來了解一下。 1、公積金余額不足。很多…

        2022年10月8日
      • 甘肅省自然資源廳與省科技廳對接科技創(chuàng)新工作

        中國甘肅網(wǎng)6月28日訊近日,省自然資源廳與省科技廳對接全省自然資源領(lǐng)域科技創(chuàng)新工作并進(jìn)行座談。 座談會上,省自然資源廳希望與省科技廳在科研合作機制、科研項目立項、創(chuàng)新平臺建設(shè)、科技…

        2022年7月5日
      • Oppo Watch 3將成為全球首款搭載驍龍W5 Gen1芯片手表

        高通除了為移動智能手機提供驍龍芯片外,還有很多產(chǎn)品。 雖然高通從流行的驍龍 8+ Gen 1 SoC中收集了良好成績,但它最近修改了可穿戴市場的產(chǎn)品。這家美國芯片制造商推出了驍龍W…

        2022年7月24日

      聯(lián)系我們

      聯(lián)系郵箱:admin#wlmqw.com
      工作時間:周一至周五,10:30-18:30,節(jié)假日休息