在线不卡日本ⅴ一区v二区_精品一区二区中文字幕_天堂v在线视频_亚洲五月天婷婷中文网站

  • <menu id="lky3g"></menu>
  • <style id="lky3g"></style>
    <pre id="lky3g"><tt id="lky3g"></tt></pre>

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

    何謂事務(wù)?

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

    • 數(shù)據(jù)庫(kù)中途突然因?yàn)槟承┰驋斓袅恕?/li>
    • 客戶端突然因?yàn)榫W(wǎng)絡(luò)原因連接不上數(shù)據(jù)庫(kù)了。
    • 并發(fā)訪問數(shù)據(jù)庫(kù)時(shí),多個(gè)線程同時(shí)寫入數(shù)據(jù)庫(kù),覆蓋了彼此的更改。
    • ……

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

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

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

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

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

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

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

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

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

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

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

    ACID

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    相關(guān)推薦

    • TES官宣knight斷開連接!網(wǎng)友:左手就是下一個(gè)369

      2022LPL冬季轉(zhuǎn)會(huì)期已經(jīng)正式到來,如果說此次轉(zhuǎn)會(huì)期熱度最高的一支隊(duì)伍,無疑就是在2022全球總決賽中拿到四強(qiáng)成績(jī)的JDG了。因?yàn)閾?jù)目前網(wǎng)上爆料人的消息來看,JDG很有可能會(huì)通過…

      2022年11月27日
    • 商家收到貨才會(huì)退款嗎(淘寶代付款退款錢到哪里了)

      在淘寶上有一些人下單購(gòu)買商品的時(shí)候是通過代付的形式來支付的,一般情況下是家長(zhǎng)幫助家里的小孩或者長(zhǎng)輩進(jìn)行代付,而代付訂單和普通的訂單沒有太大的區(qū)別,不過如果發(fā)生退款的話,錢是退到哪里…

      2022年11月25日
    • 什么是推廣cpa一篇文章帶你看懂CPA推廣渠道

      CPA渠道 CPA指的是按照指定的行為結(jié)算,可以是搜索,可以是注冊(cè),可以是激活,可以是搜索下載激活,可以是綁卡,實(shí)名認(rèn)證,可以是付費(fèi),可以是瀏覽等等。甲乙雙方可以根據(jù)自己的情況來定…

      2022年11月25日
    • 抖音直播帶貨有哪些方法技巧(抖音直播帶貨有哪些痛點(diǎn))

      如今抖音這個(gè)短視頻的變現(xiàn)能力越來越突顯了,尤其是在平臺(tái)上開通直播,更具有超強(qiáng)的帶貨屬性,已經(jīng)有越來越多的普通人加入到其中了。不過直播帶貨雖然很火,但是也不是每個(gè)人都能做好的,那么在…

      2022年11月24日
    • iPhoneSE4價(jià)格或在3000以內(nèi) 蘋果se4最新消息

      據(jù)相關(guān)爆料,明年即將在春季發(fā)布的iPhoneSE4系列,售價(jià)可能會(huì)在3000元以內(nèi),可能會(huì)使用iPhone SE4與紅米K系列直接競(jìng)爭(zhēng),打算正式進(jìn)入2000元價(jià)位市場(chǎng)。可以看出,如…

      2022年11月24日
    • 淘寶直播開通后帶貨鏈接怎么做(淘寶直播需要開通淘寶店鋪嗎)

      直播帶貨無論是對(duì)于商家來說還是主播收益都是非常可觀的,所以不少平臺(tái)都有直播帶貨功能,一些小伙伴也想加入淘寶直播,那么淘寶直播開通后帶貨鏈接怎么做?下面小編為大家?guī)硖詫氈辈ラ_通后帶…

      2022年11月24日
    • 1千克等于多少磅

      克,此定義在1958年被美國(guó)以及其他英聯(lián)邦會(huì)員國(guó)承認(rèn)換算回來,一千克等于262磅,一磅等于037千克英國(guó)在1963年開始,依據(jù)度量衡法案的規(guī);1 磅=16 盎司=04536 千克 …

      2022年11月24日
    • 明查|美國(guó)新冠后遺癥患者中有16%癥狀嚴(yán)重以致無法工作?

      點(diǎn)擊進(jìn)入澎湃新聞全球事實(shí)核查平臺(tái) 速覽 – 網(wǎng)傳數(shù)據(jù)比例無權(quán)威信源佐證,該比例有可能是結(jié)合了美國(guó)疾病防控中心和布魯金斯學(xué)會(huì)的數(shù)據(jù)得出,但這兩個(gè)機(jī)構(gòu)的調(diào)研目的和樣本都不同…

      2022年11月24日
    • 國(guó)家衛(wèi)健委:各地進(jìn)一步加大層層加碼整治力度

      據(jù)央視新聞,國(guó)家疾控局傳防司二級(jí)巡視員胡翔22日在國(guó)務(wù)院聯(lián)防聯(lián)控機(jī)制新聞發(fā)布會(huì)上介紹,近期,國(guó)務(wù)院聯(lián)防聯(lián)控機(jī)制綜合組通過視頻會(huì)商、調(diào)度和培訓(xùn)等多種方式,部署調(diào)度各地盡快推進(jìn)二十條優(yōu)…

      2022年11月23日
    • 快手限流多久能解除(快手限流什么意思)

      我相信很多人都看中了快手平臺(tái)的商機(jī),都爭(zhēng)先恐后地想要搶占機(jī)會(huì),可一些人剛剛作出一點(diǎn)成績(jī),就被降權(quán)了,自己也不知道什么原因。所以今天就來聊聊快手賬號(hào)降權(quán)操作分享,趕快來看看避免違規(guī)!…

      2022年11月23日

    聯(lián)系我們

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