成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術(shù)文章
文章詳情頁

說說MySQL中MVCC機(jī)制的原理

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

一、概述:

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

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

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

二、什么是Undo log

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

三、行的隱藏列

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

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

  • trx_id,事務(wù)號:

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

  • roll_pointer,回滾指針:

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

四、Undo log版本鏈

一開始,我們使用以下語句創(chuàng)建一個(gè)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)在開啟第一個(gè)事務(wù),事務(wù)id為1,執(zhí)行以下插入語句。

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

那么當(dāng)前的示意圖如下:

因?yàn)樵摂?shù)據(jù)是新插入的,因此它的roll_pointer指向的undo log為空。

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

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

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

當(dāng)開啟第3個(gè)事務(wù),分配到事務(wù)id是3,執(zhí)行以下修改命令。

UPDATE student SET age = 25 WHERE id = 1;

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

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

五、關(guān)于ReadView

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

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

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

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

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

簡要的示意圖如下:

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

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

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

標(biāo)簽: MySQL
相關(guān)文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
日韩一区二区麻豆国产| 欧美日韩国产片| 色妞www精品视频| 亚洲视频你懂的| 欧美激情1区| 久久久久久电影| www.日本不卡| 日韩欧美一区二区三区在线| 精品亚洲porn| 欧美日韩精品福利| 久久国产精品区| 午夜亚洲福利在线老司机| 亚洲卡通欧美制服中文| 亚洲日本欧美在线| 亚洲欧美日本在线| 亚洲精品一品区二品区三品区| 国产精品三级电影| 亚洲婷婷在线| 中文字幕亚洲成人| 永久久久久久| 亚洲精品国产a| 国产视频在线观看一区 | 狠狠色噜噜狠狠色综合久| 国产日韩欧美麻豆| 欧美成人首页| 中文字幕永久在线不卡| 国产精品视频| 日韩二区三区在线观看| 欧美影院一区二区三区| 精品一区精品二区高清| 欧美另类变人与禽xxxxx| 国产精品羞羞答答xxdd| 日韩三级视频中文字幕| av色综合久久天堂av综合| 国产日韩v精品一区二区| 亚洲视频免费| 亚洲成av人**亚洲成av**| 亚洲影视综合| 青青草97国产精品免费观看无弹窗版 | 国产亚洲欧美激情| 国产在线欧美| 樱桃国产成人精品视频| 久久成人亚洲| 麻豆极品一区二区三区| 欧美一区永久视频免费观看| 成人免费高清视频在线观看| 久久久影视传媒| 亚洲婷婷免费| 性欧美疯狂xxxxbbbb| 欧美三日本三级三级在线播放| 韩国精品一区二区| 日韩欧美国产综合| 欧美日韩视频在线一区二区观看视频| 亚洲欧美电影一区二区| 色狠狠一区二区三区香蕉| 国产一区二区三区四区五区入口 | 亚洲女同同性videoxma| 麻豆精品视频在线观看视频| 91精品久久久久久蜜臀| 午夜精品电影| 夜夜嗨av一区二区三区网页| 欧美日韩黄色影视| 99热这里都是精品| **性色生活片久久毛片| 久久久久久夜| 国产成人99久久亚洲综合精品| 久久久精品国产99久久精品芒果| 日韩一级在线| 激情图片小说一区| 日本一区二区电影| 久久野战av| 99在线精品一区二区三区| 亚洲一级二级三级| 91精品国产入口在线| 亚洲电影成人| 久久精品国产99| 国产欧美综合在线| 免费亚洲一区二区| 粉嫩欧美一区二区三区高清影视| 日韩毛片在线免费观看| 欧美性色欧美a在线播放| 欧美一区二区三区另类| 亚洲愉拍自拍另类高清精品| 欧美一区二区视频在线观看2022| 国内精品国语自产拍在线观看| 奇米色一区二区三区四区| 久久久精品综合| 久久只有精品| 欧美一区二区在线| 丝袜美腿成人在线| 久久综合九色综合97_久久久| 国产美女在线精品免费观看| 成人av在线电影| 五月婷婷色综合| 久久伊人中文字幕| 久久亚洲电影| 欧美日本二区| 国产一区二区看久久| 一区二区在线观看视频| 日韩欧美高清一区| 久久亚洲综合网| 欧美日韩理论| 国产精品一区一区三区| 亚洲综合一区在线| 日韩精品一区二区三区视频播放 | 日韩精品1区2区3区| 久久综合色播五月| 在线观看亚洲精品| 狠狠入ady亚洲精品经典电影| 国产专区欧美精品| 亚洲精品日日夜夜| 日韩你懂的电影在线观看| 久久激情久久| 国精品一区二区三区| 国产成人福利片| 日韩二区三区四区| 亚洲黄一区二区三区| 久久久99精品久久| 欧美日韩国产另类不卡| 国产精品乱码一区二区三区| 欧美二区不卡| 国产盗摄精品一区二区三区在线| 午夜精品久久久久久久久| 国产亚洲人成网站| 91精品国产入口| 色偷偷久久人人79超碰人人澡| 亚洲国产日韩在线| 91在线看国产| 国产成人精品免费| 久久精品99国产精品| 亚洲成av人**亚洲成av**| 国产精品色在线| 久久色在线视频| 欧美日韩国产一级片| 久久精品男女| 亚洲精品社区| 午夜欧美理论片| 成人激情黄色小说| 激情综合网av| 日韩成人一级大片| 亚洲精品国产品国语在线app| 国产区在线观看成人精品| 日韩一区二区在线观看视频| 91久久国产最好的精华液| 亚洲久久一区二区| 欧美黄免费看| 91亚洲精品久久久蜜桃| 懂色一区二区三区免费观看| 奇米影视一区二区三区| 婷婷亚洲久悠悠色悠在线播放| 亚洲免费观看高清在线观看| 国产精品久久久久国产精品日日| 久久久久国产精品免费免费搜索| 欧美成人伊人久久综合网| 欧美情侣在线播放| 久久美女性网| 中文久久精品| 亚洲日韩视频| 136国产福利精品导航网址| 91香蕉视频污在线| 床上的激情91.| 国产成人在线影院| 国产成人一区在线| 国产二区国产一区在线观看| 国产一区二区三区四区在线观看| 精品一二线国产| 久久er精品视频| 老司机午夜精品99久久| 免费观看成人av| 激情六月婷婷久久| 国产在线观看免费一区| 久久精品久久精品| 久色婷婷小香蕉久久| 免费观看一级欧美片| 麻豆久久久久久| 国产资源在线一区| 国产成人在线色| 成人的网站免费观看| jizz一区二区| 欧美高清视频一区| 国产综合精品一区| 99成人在线| 国产亚洲精品自拍| 久久国产精品亚洲va麻豆| 久久久亚洲一区| 欧美三级电影网| 欧美乱妇一区二区三区不卡视频| 欧美日韩一区三区四区| 在线播放亚洲一区| 欧美成人精精品一区二区频| 国产天堂亚洲国产碰碰| |精品福利一区二区三区| 亚洲图片欧美色图| 日韩电影一二三区| 国产综合一区二区| eeuss鲁一区二区三区| 激情偷拍久久| 国产精品一区二区三区观看| 老司机精品福利视频| 欧美日本乱大交xxxxx|