久久精品五月,日韩不卡视频在线观看,国产精品videossex久久发布 ,久久av综合

站長資訊網
最全最豐富的資訊網站

一文淺析MySQL怎么解決幻讀問題

MySQL是如何解決幻讀問題的?下面本篇文章就來帶大家聊聊這個問題,下面就來帶著問題一起看看文章吧!

一文淺析MySQL怎么解決幻讀問題

??金不三,銀不四的高頻面試題中,MySQL的事務特性,隔離級別等問題也是非常經典八股文之一,面對此種問題,估計絕大數小伙伴也是信手拈來的事情:

事務特性(ACID)原子性Atomicity)、隔離性Isolation)、一致性Consistency)和持久性

隔離級別讀取未提交READ UNCOMMITTED),讀取已提交READ COMMITTED),可重復讀REPEATABLE READ),可串行化SERIALIZABLE

而每一種隔離級別導致的問題有:

  • READ UNCOMMITTED隔離級別下,可能發生臟讀不可重復讀幻讀問題
  • READ COMMITTED隔離級別下,可能發生不可重復讀幻讀問題,但是不可以發生臟讀問題
  • REPEATABLE READ隔離級別下,可能發生幻讀問題,但是不可以發生臟讀不可重復讀的問題
  • SERIALIZABLE隔離級別下,各種問題都不可以發生

對于MySQL InnoDB 存儲引擎的默認支持的隔離級別是 REPEATABLE-READ(可重讀),從上面的SQL標準的四種隔離級別定義可知,REPEATABLE-READ(可重復讀)是不可以防止幻讀的,但是我們都知道,MySQL InnoDB存儲引擎是解決了幻讀問題發生的,那他又是如何解決的呢?

1. 行格式

??在進入主題之前,我們先大致了解一下什么是行格式,這樣有助于我們理解下面的MVCC,行格式是表中的行記錄在磁盤的存放方式,Innodb存儲引擎總共有4種不同類型的行格式:compact、redundant、dynamiccompress;雖然很很多行格式,但是在原理上,大體都相同,如下,為compact行格式:一文淺析MySQL怎么解決幻讀問題??從圖中可以看出來,一條完整的記錄其實可以被分為記錄的額外信息記錄的真實數據兩大部分,記錄的額外信息分別是變長字段長度列表、NULL值列表記錄頭信息,而記錄的真實數據除了我們自己定義的列之外,MySQL會為每個記錄添加一些默認列,這些默認列又稱為隱藏列,具體列如下:

列名 長度 描述
row_id 6個字節 行ID,唯一標識一條記錄
transaction_id 6個字節 事務ID
roll_pointer 7個字節 回滾指針

隱藏列的值不用我們操心,InnoDB存儲引擎會自己幫我們生成的,畫得再詳細一點,compact行格式如下:

一文淺析MySQL怎么解決幻讀問題

  • transaction_id :事物id,當事物對行記錄進行修改時,都會將本事物的事物id賦值到該列
  • roll_pointer:每次在對行記錄進行改動的時候,都會把舊版本的數據寫入undolog日志,然后將roll_pointer 指向該undolog,所以該列相當于一個指針,通過該列,可以找到修改之前的信息

2. MVCC詳解

2.1 版本鏈

假設有一條記錄如下:一文淺析MySQL怎么解決幻讀問題插入該記錄的事務id80roll_pointer 指針為NULL(為了便于理解,讀者可理解為指向為NULL,實際上roll_pointer第一個比特位就標記著它指向的undo日志的類型,如果該比特位的值為1時,就代表著它指向的undo日志類型為insert undo)

假設之后兩個事務id分別為100200的事務對這條記錄進行UPDATE操作:

 -- 事務id=100  update person set grade =20 where id =1;  update person set grade =40 where id =1;  -- 事務id=200  update person set grade =70 where id =1;
登錄后復制

??每次對記錄進行改動,都會記錄一條undo日志,每條undo日志也都有一個roll_pointer屬性(INSERT操作對應的undo日志沒有該屬性,因為該記錄并沒有更早的版本),可以將這些undo日志都連起來,串成一個鏈表,所以現在的情況就像下圖一樣:

一文淺析MySQL怎么解決幻讀問題??對該記錄每次更新后,都會將舊值放到一條undo日志中,就算是該記錄的一個舊版本,隨著更新次數的增多,所有的版本都會被roll_pointer屬性連接成一個鏈表,我們把這個鏈表稱之為版本鏈,版本鏈的頭節點就是當前記錄最新的值。另外,每個版本中還包含生成該版本時對應的事務id

2.2 ReadView

??對于數據庫的四種隔離級別:1)read uncommitted;2) read committed;3) REPEATABLE READ; 4)SERIALIZABLE;來說,READ UNCOMMITTED,每次讀取版本鏈的最新數據即可;SERIALIZABLE,主要是通過加鎖控制;而read committedREPEATABLE READ都是讀取已經提交了的事物,所以對于這兩個隔離級別,核心問題是版本鏈中,哪些事物是對當前事物可見;為了解決這個問題,MySQL提出了read view 概念,其包含四個核心概念:

  • m_ids:生成read view 時候,活躍的事物id集合
  • min_trx_idm_ids的最小值,既生成read view的時候,活躍事物的最小值
  • max_trx_id:表示生成read view的時候,系統應該分配下一個事物id值
  • creator_trx_id:創建read view的事物id,即當前事物id。

有了這個ReadView,這樣在訪問某條記錄時,只需要按照下邊的步驟判斷記錄的某個版本是否可見:一文淺析MySQL怎么解決幻讀問題

  • 當記錄的事物id等于creator_trx_id的時候,說明當前事物正在訪問自己修改的記錄,所以該版本可見
  • 如果被訪問的版本事物id小于min_trx_id的時候,則說明,在創建read view的時候,該事物已經提交,該版本,對當前事物可讀
  • 如果被訪問的版本事物id大于或等于max_trx_id,則說明創建該read view的時候,該說明生成該版本記錄的事物id在生成Read view之后才開啟,所以該版本不能被當前事物可讀
  • 如果被訪問的版本事物transaction_idm_ids集合中,說明生成Read view的時候,該事物還是活躍的,還沒有被提交,則該版本不可以被訪問;如果不在,則說明創建ReadView時生成該版本的事務已經被提交,可以被訪問

注:讀事物的事物id為0

MySQL中,READ COMMITTEDREPEATABLE READ隔離級別的的一個非常大的區別就是它們生成ReadView的時機不同:

  • READ COMMITTED —— 每次讀取數據前都生成一個ReadView
  • REPEATABLE READ —— 在第一次讀取數據時生成一個ReadView

下面我們通過詳細例子來說明,兩者有何不同:

時間編號 trx 100 trx 200
BEGIN;
BEGIN; BEGIN;
update person set grade =20 where id =1;
update person set grade =40 where id =1;
SELECT * FROM person WHERE id = 1;
COMMIT;
update person set grade =70 where id =1;
SELECT * FROM person WHERE id = 1;
COMMIT;
? COMMIT;

在時間④中,因事務trx 100 執行了事務的提交,id=1行記錄的版本鏈如下:

一文淺析MySQL怎么解決幻讀問題在時間⑥中,因事務trx 200 執行了事務的提交,id=1行記錄的版本鏈如下:

一文淺析MySQL怎么解決幻讀問題

在時間⑤,事務trx 100執行select語句時會先生成一個ReadView,ReadViewm_ids列表的內容就是[100, 200]min_trx_id100max_trx_id201,creator_trx_id0,此時,從版本鏈中選可見的記錄,版本鏈從上到下遍歷:因為grade=40,trx_id值為100,在m_ids里,所以該記錄不可見,同理,grade=20的也不見。繼續往下遍歷,grade=20,trx_id值為80,小于小于ReadView中的min_trx_id100,所以這個版本符合要求,返回給用戶的是等級為10的記錄。

在時間⑧中,如果事務的隔離級別是READ COMMITTED,會單獨又生成一個ReadView,該ReadViewm_ids列表的內容就是[200],min_trx_id200,max_trx_id201,creator_trx_id0,此時,從版本鏈中選可見的記錄,版本鏈從上到下遍歷:因為grade=70,trx_id值為200,在m_ids里,所以該記錄不可見,繼續往下遍歷,grade=40,trx_id值為100,小于ReadView中的min_trx_id200,所以這個版本是符合要求的,返回給用戶的是是等級為40的記錄。

在時間⑧中,如果事務的隔離級別是 REPEATABLE READ,在時間⑧中,不會單獨生成一個ReadView,而是沿用時間5的ReadView,所以返回給用戶的等級是10。前后兩次select得到的是一樣的,這就是可重復讀的含義。

3. 總結

??通過分析MVCC詳解部分,可以得出,基于MVCC,在RR隔離級別下,很好解決了幻讀問題,但是我們知道,select for update是產生當前讀,不再是快照讀,那么此種情況,MySQL又是怎么解決幻讀問題的呢?基于時間問題(整理畫圖的確需要花比較多的時間),此處先給結論,后面再分析在當前讀的情況下,MySQL是怎么解決幻讀問題:

  • 當前讀 : 使用 Next-Key Lock(間隙鎖) 進行加鎖來保證不出現幻讀

對于間隙鎖是如何在當前讀的情況下解決幻讀問題的,感興趣朋友可加個關注,點個贊

贊(0)
分享到: 更多 (0)
?
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
久久精品五月,日韩不卡视频在线观看,国产精品videossex久久发布 ,久久av综合
欧美午夜不卡| 久久av超碰| 日韩精品看片| 国产伊人精品| 每日更新成人在线视频| 国产一区久久| 亚洲精品小说| 日韩视频一区二区三区在线播放免费观看 | 美女视频黄免费的久久| 欧美日韩三区| 亚洲欧美日韩精品一区二区 | 特黄特色欧美大片| 韩国精品主播一区二区在线观看| 99久久九九| 蜜臀av国产精品久久久久| 丝袜脚交一区二区| 欧美视频久久| 久久69成人| 99久久婷婷| 亚州欧美在线| 激情中国色综合| 日韩视频在线一区二区三区| 欧美日韩一区二区国产| 欧美日韩国产v| 丝袜亚洲另类欧美 | 日韩国产欧美在线视频| 日本成人在线网站| 久久精品国产成人一区二区三区 | 美腿丝袜亚洲一区| 99精品综合| 欧美在线91| 99久久精品费精品国产| 日韩二区在线观看| 免费观看亚洲| 免费在线观看视频一区| 久久久久97| 99视频一区| 国产精品极品| 亚洲一区日韩在线| 国产精品久久久久毛片大屁完整版 | 国产亚洲电影| 911亚洲精品| 国产在线观看91一区二区三区| 蜜臀av免费一区二区三区| 日韩福利视频网| 日韩在线视频精品| 日韩有码av| 亚洲午夜在线| 久久免费视频66| 蜜桃久久av一区| 久久久精品五月天| 国产极品模特精品一二 | 在线午夜精品| 国产精品色在线网站| 五月精品视频| 精品国产18久久久久久二百| 亚洲欧洲美洲国产香蕉| 久久国产中文字幕| 精品国产一区二区三区性色av| 免费看精品久久片| 999久久久精品国产| 精品国产精品久久一区免费式| 美女精品网站| 久久中文字幕二区| 国产精品videosex极品| 亚洲免费一区三区| 亚洲一区二区三区四区五区午夜| 98精品久久久久久久| 日韩精品视频中文字幕| 国产麻豆综合| 日韩视频不卡| 欧美日韩国产在线观看网站| 日韩免费在线| 国产激情一区| 国产精品网址| 国产欧美88| 欧美日一区二区三区在线观看国产免| 日韩精品一区第一页| 欧美在线网站| 久久久久国产| 欧洲精品一区二区三区| 国产成人77亚洲精品www| 久久av影视| 国产精品视频一区二区三区四蜜臂 | 青草国产精品久久久久久| 亚洲午夜久久久久久尤物 | 久久久久97| 久久精品伊人| 成人午夜亚洲| 精品国产精品国产偷麻豆| 欧美成人一二区| 久久精品亚洲| 国产传媒在线观看| 欧洲一区二区三区精品| 捆绑调教日本一区二区三区| 福利在线免费视频| 日本不良网站在线观看| 日韩免费视频| 九九久久电影| 国产亚洲在线观看| 日韩中文字幕av电影| 免费黄网站欧美| 18国产精品| 免费一级欧美片在线观看网站| 精品理论电影在线| 久久激情婷婷| 久久亚洲精品伦理| 婷婷综合福利| 欧美1区二区| 日韩av在线播放网址| 日韩欧美精品一区| 不卡视频在线| 一级欧美视频| 国产精品v日韩精品v欧美精品网站| 国产精品a级| 福利一区和二区| 欧美色图一区| 天海翼亚洲一区二区三区| 欧美在线首页| 久久精品国产999大香线蕉| 中文在线а√天堂| 在线 亚洲欧美在线综合一区| 亚洲a级精品| 精品国产一区二区三区av片| 91视频一区| 激情综合网站| 日本午夜精品| 日韩伦理在线一区| 亚洲一区中文| 国产调教精品| 久久婷婷av| 日本天堂一区| 久久精品成人| 日韩和欧美一区二区| 日韩av有码| 蜜臀久久99精品久久久久宅男| 国产精品一页| av亚洲在线观看| 国产乱人伦丫前精品视频| 青青久久av| 亚洲一区二区三区久久久| 久久精品网址| 老司机久久99久久精品播放免费| 国产精品一线天粉嫩av| 欧美日韩高清| 美女在线视频一区| 奶水喷射视频一区| jizzjizz中国精品麻豆| 午夜精品福利影院| 日本精品在线中文字幕| 欧美亚洲三级| 黄色欧美日韩| 精品国产中文字幕第一页| 亚洲欧美日韩国产| 首页国产精品| 亚洲综合五月| 久久久久午夜电影| 美女在线视频一区| 亚洲精品影院在线观看| 91精品一区国产高清在线gif| 国产精品久久久久久久久免费高清 | 国产乱码精品一区二区三区四区 | 国产精品红桃| 亚洲在线一区| 色在线中文字幕| 国产精品网址| 亚洲精品高潮| 蜜臀av免费一区二区三区| 精品午夜久久| 欧美精品三级在线| 亚洲深夜福利在线观看| 久久久天天操| 久久不卡国产精品一区二区| 亚洲最新av| 日韩视频在线一区二区三区 | 欧美日韩一区自拍| 亚洲免费影院| 欧美日韩在线播放视频| 国产一区二区精品久| 国产午夜久久av| 亚洲精品乱码| 亚洲在线电影| 91精品福利| 欧美一区二区性| 成人污污视频| 亚洲三级网址| 国产视频一区免费看| 99精品国产一区二区三区| 9999国产精品| 精品国产精品久久一区免费式 | 日韩精品一二三区| 99精品国产一区二区三区| 精品一区二区男人吃奶| 国产精品观看| 国产精品嫩草影院在线看| 国产免费av国片精品草莓男男| 青青草精品视频| 日本不卡一二三区黄网| 日韩精品视频在线看| 日韩一区精品视频|