這篇文章主要介紹“MySQL中InnoDB的MVCC是通過什么來實(shí)現(xiàn)的”,在日常操作中,相信很多人在mysql中InnoDB的MVCC是通過什么來實(shí)現(xiàn)的問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”mysql中InnoDB的MVCC是通過什么來實(shí)現(xiàn)的”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!
成都創(chuàng)新互聯(lián)主要從事網(wǎng)站制作、成都做網(wǎng)站、網(wǎng)頁設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)福貢,10年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):028-86922220
1、InnoDB的MVCC是通過在每行記錄后面保存兩個(gè)隱藏的列來實(shí)現(xiàn)的。
這兩個(gè)列,一個(gè)保存了銀行的事務(wù)ID,一個(gè)保存了銀行的回滾指針。
2、每次開始新的事務(wù),都會自動增加新的事務(wù)id。
事務(wù)開始時(shí),事務(wù)id會被放置在當(dāng)前事務(wù)影響的交易id中。查詢時(shí),需要比較當(dāng)前事務(wù)id和每行記錄的交易id。
實(shí)例
假如有個(gè)事務(wù)開始于 update 之后 delete 之前,且結(jié)束于 delete 之后,如下:
start transaction; //假如事務(wù) id = 2.5 select * from test; //執(zhí)行時(shí)間在 update 之后 delete 之前 select * from test; //執(zhí)行時(shí)間在 delete 之后 commit;
如果不使用 MVCC 第一條 select * from test 能讀到 1 條記錄,而 第二條將讀取到 0 條記錄,同一事務(wù)中多次 select 范圍查詢讀取到的記錄不一致即幻讀。而使用 MVVC 之后,兩條select 語句讀取到的記錄相同。
到此,關(guān)于“mysql中InnoDB的MVCC是通過什么來實(shí)現(xiàn)的”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!