mysql多版本并發(fā)控制MVCC的實(shí)現(xiàn)
事務(wù)隔離級別設(shè)置
set global transaction isolation level read committed; //全局的 set session transaction isolation level read committed; //當(dāng)前會話
修改事務(wù)提交方式(是否自動提交,mysql默認(rèn)自動提交)
SET AUTOCOMMIT = 1; //自動提交,為0手動提交
不同數(shù)據(jù)庫引擎MVCC模式各不相同,典型有樂觀和悲觀并發(fā)控制。
innodb
說明:
InnoDB的MVCC,是通過在每行記錄后面保存兩個隱藏的列來實(shí)現(xiàn)的。這兩個列,一個保存了行的創(chuàng)建時間,一個保存行的過期時間(或刪除時間)。當(dāng)然存儲的并不是實(shí)際的時間值,而是系統(tǒng)版本號(system version number).每開始個新的事務(wù),系統(tǒng)版本號都會自動遞增。事務(wù)開始時刻的系統(tǒng)版本號會作為事務(wù)的版本號,用來和查詢到的
SELECT
InnoDB會根據(jù)以下兩個條件檢查每行記錄:
a. InnoDB只查找版本早于當(dāng)前事務(wù)版本的數(shù)據(jù)行(也就是,行的系統(tǒng)版本號小于或等于事務(wù)的系統(tǒng)版本號),這樣可以確保事務(wù)讀取的行,要么是在事務(wù)開始前已經(jīng)存在的,要么是事務(wù)自身插人或者修改過的。
b.行的刪除版本要么未定義,要么大于當(dāng)前事務(wù)版本號。這可以確保事務(wù)讀取到的行,在事務(wù)開始之前未被刪除。
只有符合上述兩個條件的記錄,才能返回作為查詢結(jié)果。
INSERT
InnoDB為新插人的每行 保存當(dāng)前系統(tǒng)版本號作為行版本號。
DELETE
InnoDB為刪除的每行保存當(dāng)前系統(tǒng)版本號作為行刪除標(biāo)識。
UPDATE
InnoDB為插人行新記錄,保存當(dāng)前系統(tǒng)版本號作為行版本號,同時保存當(dāng)前系統(tǒng)版本號到原來的行作為行刪除標(biāo)識。
注意:
MVCC只在REPEATABLE READ 和READ COMMITED 兩個隔離級別下工作。其他兩個隔離級別都和MVCC不兼容法,因?yàn)镽EAD UNCOMITTED總是讀取最新的數(shù)據(jù)行,而不是符合當(dāng)前事務(wù)版本的數(shù)據(jù)行。而SERIALIZABLE則會對所有讀取的行都加鎖。
查看當(dāng)表的狀態(tài)
show table status like 'task'\G;
臟讀、不可重復(fù)讀、幻讀
臟讀:當(dāng)前事務(wù)讀到了另一個事務(wù)未提交的狀態(tài),事務(wù)沒有實(shí)現(xiàn)隔離。
不可重復(fù)讀:實(shí)現(xiàn)了事務(wù)的隔離性,但兩次讀取同一條數(shù)據(jù)的時候發(fā)現(xiàn)數(shù)據(jù)不一致了。
幻讀:兩次查詢同一批數(shù)據(jù),發(fā)現(xiàn)有新數(shù)據(jù)被插入,主要是因?yàn)橹型居衅渌聞?wù)對數(shù)據(jù)集進(jìn)行了插入操作。(加了間隙鎖解決該問題)
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
MySQL更改數(shù)據(jù)字段的前幾位數(shù)字的方法示例
本文主要介紹了MySQL更改數(shù)據(jù)字段的前幾位數(shù)字的方法示例,包括使用SUBSTRING函數(shù)、REPLACE函數(shù)、LEFT函數(shù),還是正則表達(dá)式或者CASE語句,具有一定的參考價值,感興趣的可以了解一下2024-08-08Windows Server2019安裝MySQL5.7.25的方法
這篇文章主要介紹了Windows Server2019安裝MySQL5.7.25,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-09-09Mysql關(guān)于進(jìn)程中的死鎖和解除鎖問題
Mysql 經(jīng)常會遇到語句或者存儲過程長時間沒有反應(yīng),大概率就是掛掉了,或者死鎖了,這篇文章主要介紹了Mysql關(guān)于進(jìn)程中的死鎖和解除鎖問題,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-07-07php開啟mysqli擴(kuò)展之后如何連接數(shù)據(jù)庫
Mysqli是php5之后才有的功能,沒有開啟擴(kuò)展的朋友可以打開您的php.ini的配置文件;相對于mysql有很多新的特性和優(yōu)勢,需要了解的朋友可以參考下2012-12-12mysql 發(fā)生系統(tǒng)錯誤1067的解決方法
今天要把WEB項(xiàng)目打包成EXE,可是在數(shù)據(jù)庫上卡住了。在啟動數(shù)據(jù)庫服務(wù)的時候發(fā)生系統(tǒng)錯誤 1067。2009-09-09