日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

說說MySQL中MVCC機制的原理

瀏覽:285日期:2023-05-05 10:12:08
目錄
  • 一、概述:
  • 二、什么是Undo log
  • 三、行的隱藏列
  • 四、Undo log版本鏈
  • 五、關于ReadView
    • ReadView包含以下幾個重要的參數(shù):

一、概述:

了解了MySql的底層架構后,我們今天要深入了解下什么是MVCC。

MVCC,全稱Multi-Version Concurrency Control,即多版本并發(fā)控制。MVCC是一種多并發(fā)控制的方法,一般在數(shù)據(jù)庫管理系統(tǒng)中,實現(xiàn)對數(shù)據(jù)庫的并發(fā)訪問,在編程語言中實現(xiàn)事務內存。
我們知道,MySql在5.5后由MyISAM存儲引擎改成了InnoDB存儲引擎,主要是因為InnoDB是支持事務的,那么當多線程同時執(zhí)行的時候,可能會出現(xiàn)并發(fā)問題。這個時候可能會出現(xiàn)一個能夠控制并發(fā)的方法,MVCC就起到了這個作用。

MVCC主要靠undo log版本鏈與ReadView來實現(xiàn)。

二、什么是Undo log

  • Undo log主要用于事務回滾時恢復原來的數(shù)據(jù)。
  • mysql在執(zhí)行sql時,會將一天邏輯相反的日志保存到undo log中。因此,undo log中記錄的也是邏輯日志。
  • 但mysql執(zhí)行Insert語句時,會在undo log日志中記錄本次插入的主鍵id。等事務回滾時,delete刪除此id。
  • 當MySQL執(zhí)行update語句時,會在undo log中保存修改前的數(shù)據(jù)。等事務回滾時,再執(zhí)行一次update,得到原來的數(shù)據(jù)。
  • 當MySQL執(zhí)行delete語句時,會在undo log中保存刪除前的數(shù)據(jù)。等事務回滾時,再執(zhí)行insert,插入原來的數(shù)據(jù)。
  • 數(shù)據(jù)庫中的四大特性–原子性,即事務是不可分割的,要么全部成功,要不全部失敗,其底層就靠undo log來實現(xiàn)。在執(zhí)行某一條語句失敗時,就會對之前事務的語句進行回滾。

三、行的隱藏列

  • 在數(shù)據(jù)庫的每行上,除了存放真實的數(shù)據(jù)以外,還存在3個隱藏的列:row_id、trx_id和roll_pointer
  • row_id,行號:

如果當前表有整數(shù)類型的主鍵,那么row_id的值就是主鍵的值
如果沒有整數(shù)類型的主鍵,則MySQL會按照字段的順序選擇一個非空的整數(shù)類型的唯一索引為row_id
如果都沒有找到,則會創(chuàng)建一個自動增長的整數(shù)作為row_id

  • trx_id,事務號:

當一個事務開始執(zhí)行前,MySQL就會為這個事務分配一個全局自增的事務id。
之后該事務對當前進行的增、改、刪除等操作時,都會將自己的事務ID記錄到trx_id中。

  • roll_pointer,回滾指針:

事務對當前數(shù)據(jù)改動時,會將舊的數(shù)據(jù)記錄到undo log中,在將數(shù)據(jù)寫入當前行,且當前的roll_pointer指向剛才那個undo log,因此可通過roll_pointer來找到改行前一個版本。
當一直有事務對該行改動時,就會一直生成undo log,最終將會形成undo log版本鏈。

四、Undo log版本鏈

一開始,我們使用以下語句創(chuàng)建一個stduent表

CREATE TABLE `student` (	`id` INT ( 11 ) NOT NULL AUTO_INCREMENT,	`name` VARCHAR ( 255 ) NOT NULL,	`age` INT ( 11 ) NOT NULL,  PRIMARY KEY ( `id` ) USING BTREE ) ENGINE = INNODB;

現(xiàn)在開啟第一個事務,事務id為1,執(zhí)行以下插入語句。

INSERT INTO student VALUES ( 1, "a", 24 );

那么當前的示意圖如下:

因為該數(shù)據(jù)是新插入的,因此它的roll_pointer指向的undo log為空。

接著開啟第2個事務,分配的事務id是2,執(zhí)行以下修改命令。

UPDATE student SET NAME = "b" WHERE id = 1;

現(xiàn)在的示意圖變?yōu)椋?/p>

當開啟第3個事務,分配到事務id是3,執(zhí)行以下修改命令。

UPDATE student SET age = 25 WHERE id = 1;

示意圖變?yōu)椋?/p>

每個事務對該行進行改動時,都會生成一個undo log,用于保存之前的版本,之后再將新版本的roll_pointer指向剛才生成的undo log。
因此,roll_pointer可以將這些不同版本的undo log串聯(lián)起來,形成undo log的版本鏈。

五、關于ReadView

首先需要理解一下快照讀與當前讀
快照讀:簡單的select查詢,即不包括 select … lock in share mode, select … for update,可能會讀到數(shù)據(jù)的歷史版本。
當前讀:以下語句都是當前讀,總是讀取最新版本,會對讀取的最新版本加鎖。

select ... lock in share modeselect ... for updateinsertupdatedelete

在事務執(zhí)行每一個快照讀或事務初次執(zhí)行快照讀時,會生成一致性視圖,即ReadView。
ReadView的作用是,判斷undo log版本鏈中的哪些數(shù)據(jù)對當前事務可見。

ReadView包含以下幾個重要的參數(shù):

  • m_ids
    • 在創(chuàng)建ReadView的那一刻,mysql中所有未提交的事務id集合。
  • min_trx_id
    • m_ids中的最小值
  • max_trx_id
    • mysql即將為下一個事務分配的事務id,并不是m_ids中的最大值。
  • creator_trx_id
    • 即創(chuàng)建此ReadView的事務id

簡要的示意圖如下:

那么事務在執(zhí)行快照讀時,可以通過以下的規(guī)則來確定undo log版本鏈上的哪個版本數(shù)據(jù)可見。

  • 如果當前undo log的版本的trx_id<min_trx_id,說明該版本對應的事務在生成ReadView之前就已經(jīng)提交了,因此是可見的。
  • 如果當前undo log的版本的trx_id≥max_trx_id,說明該版本對應的事務在生成ReadView之后才開始的,因此是不可見的。
  • 如果當前undo log的版本的trx_id∈[min_trx_id,max_trx_id),如果在這個范圍里,還要判斷trx_id是否在m_ids中:
  在m_ids中,說明版本對應的事務未提交,因此是不可見的。  不在m_ids中,說明版本對應的事務已經(jīng)提交,因此是可見的。
  • 如果當前undo log的版本的trx_id=creator_trxt_id,說明事務正在訪問自己修改的數(shù)據(jù),因此是可見的。
  • 當undo log版本鏈表的頭結點數(shù)據(jù)被判定為不可見時,則利用roll_pointer找到上一個版本,再進行判斷。如果整個鏈表中都沒有找到可見的數(shù)據(jù),則代表當前的查詢找不到數(shù)據(jù)。

到此這篇關于說說MySQL中MVCC機制的原理的文章就介紹到這了,更多相關MySQLMVCC機制內容請搜索以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持!

標簽: MySQL
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲一二av| 亚洲国产专区| 性感美女一区二区在线观看| 欧美日韩精品一本二本三本 | 亚洲人成精品久久久| 不卡福利视频| 久久精品一区二区国产| 免费的成人av| 国产成人精品福利| 精品黄色一级片| 成人国产精品一区二区网站| 日本不卡一区二区| 91欧美极品| 蜜臀91精品一区二区三区| 亚洲综合日韩| 婷婷综合福利| 九色porny丨国产首页在线| 久久中文亚洲字幕| 蜜臀精品久久久久久蜜臀 | 日韩精品社区| 亚洲二区视频| 日韩影院在线观看| 欧美1区二区| 国产精品久久久免费| 欧美精品不卡| 久久蜜桃av| 亚洲精品成人一区| 久久午夜影院| 欧美.日韩.国产.一区.二区| 亚洲精品a级片| 国产一区91| 国产日韩亚洲欧美精品| 欧美亚洲tv| 色偷偷偷在线视频播放| 午夜精品免费| 国产精品4hu.www| 久久精品国产www456c0m| 视频在线在亚洲| 国产精品久久乐| 欧美另类综合| 国产精品4hu.www| 青青青免费在线视频| 水蜜桃久久夜色精品一区的特点 | 五月天综合网站| 亚洲图片久久| 国产在线一区不卡| 日韩精品一区二区三区中文| 国产精品一区二区三区av麻| 国产高清一区| 麻豆免费精品视频| 欧美亚洲自偷自偷| 日韩欧美一区二区三区免费看| 亚洲一区日韩| 亚洲成a人片| 国产精品一区二区美女视频免费看 | 久久国产免费| 国产精品三p一区二区| 亚洲精品一区二区在线看| 国产精品久久久久久久久久齐齐 | 久草精品视频| 久久亚洲风情| 亚洲精品一区二区妖精| 国产毛片精品| 麻豆成人在线| 99精品视频在线| 久久久久一区| 麻豆久久一区| 六月丁香综合在线视频| 日本久久一区| 精品免费在线| 国产欧美一区二区三区米奇| 蜜臀va亚洲va欧美va天堂| 伊人久久亚洲热| 麻豆高清免费国产一区| 另类综合日韩欧美亚洲| 日韩精品视频中文字幕| 国产日韩免费| 日韩av网站在线观看| 国产精品主播| 精品一区二区三区中文字幕在线| 日韩欧美精品| 日韩国产专区| 欧美日韩一二三四| 国产一在线精品一区在线观看| 亚洲一级在线| 美女精品在线| 午夜精品免费| 97精品久久| 亚洲在线久久| 国产欧美三级| 美女国产一区二区三区| 久久这里只有精品一区二区| 麻豆成人av在线| 99久久精品网站| 一区久久精品| 日韩高清中文字幕一区| 久久精品免视看国产成人| 女人天堂亚洲aⅴ在线观看| 亚洲激情国产| 国产精品男女| 欧美天堂亚洲电影院在线观看| 水蜜桃久久夜色精品一区的特点| 香蕉久久久久久| 色婷婷综合网| 国产亚洲永久域名| 久久久男人天堂| 午夜一级久久| 裤袜国产欧美精品一区| 石原莉奈在线亚洲二区| 日韩欧美另类一区二区| 在线看片日韩| 成人在线网站| 97久久超碰| 亚洲作爱视频| 国产精品原创| 国产精品大片免费观看| 99视频在线精品国自产拍免费观看| 日韩在线中文| 亚洲精品欧洲| 亚洲欧美视频| 精品国产第一福利网站| 日韩av中文字幕一区二区三区| 黄色精品网站| 日韩欧美精品一区| 久久激情五月激情| 亚洲永久字幕| 欧美一级精品| 久久福利影视| 成人看片网站| 久久久水蜜桃av免费网站| 日本不卡不码高清免费观看 | 欧美aⅴ一区二区三区视频| 男女男精品网站| 免费av一区二区三区四区| 亚洲欧美日韩高清在线| 亚洲成人国产| 日韩在线第七页| 色在线视频观看| 欧美精品自拍| 欧美特黄一区| 国产乱码精品一区二区三区亚洲人| 中文字幕免费精品| 日韩一区二区三区免费视频| 黄色国产精品| 亚洲欧美网站在线观看| 日韩中文字幕1| 99riav国产精品| 蜜桃视频一区二区三区| 亚洲一区二区日韩| 综合视频一区| 国产精品一卡| 免费在线观看一区| 色婷婷综合网| 国产一区二区三区久久| 欧美精品高清| 天堂网av成人| 亚洲一区中文| 久久精品午夜| 日韩一区电影| 亚洲午夜国产成人| 亚洲伊人精品酒店| 亚洲精品在线a| 精品一区二区三区四区五区| 国产 日韩 欧美一区| 综合激情婷婷| 蜜桃久久久久| 91超碰国产精品| 91亚洲精品在看在线观看高清| 亚洲综合电影| 亚洲免费激情| 国产成人精品福利| 欧美日韩第一| 青草国产精品久久久久久| 成人在线网站| 日韩欧美久久| av不卡在线看| 国产精品1luya在线播放| 日韩亚洲在线| 欧美日韩网址| 美日韩精品视频| 精品视频国内| 日韩和欧美一区二区| 欧美日韩网址| 午夜国产精品视频| 韩国精品主播一区二区在线观看| 中文在线日韩| 久久精品99久久无色码中文字幕| 日韩精品中文字幕吗一区二区| 米奇777超碰欧美日韩亚洲| 喷白浆一区二区| 欧美午夜精品一区二区三区电影| 国产精品久久| 伊人久久亚洲热| 天堂日韩电影| 国产精品一区三区在线观看| 国产一卡不卡| 亚洲一区二区三区久久久| 免费国产自线拍一欧美视频| av综合电影网站| 国产精品亚洲综合久久|