亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

RR與RC隔離級別下索引和鎖的測試腳本示例代碼

2024-07-25 19:09:23
字體:
來源:轉載
供稿:網友

基本概念

當前讀與快照讀

在MVCC中,讀操作可以分成兩類:快照讀 (snapshot read)與當前讀 (current read)。 快照讀,讀取的是記錄的可見版本 (有可能是歷史版本),不用加鎖。當前讀,讀取的是記錄的最新版本,并且對返回的記錄,都會加上鎖,保證在事務結束前,這條數據都是最新版本。

快照讀:簡單的select操作,屬于快照讀,不加鎖(Serializable除外)。

select * from table where ?;

當前讀:特殊的讀操作,插入/更新/刪除操作,屬于當前讀,需要加鎖?!?/p>

select * from table where ? lock in share mode;select * from table where ? for update;insert into table values ();update table set ? where ?;delete from table where ?;

隔離級別與加鎖機制

  • Read Uncommitted 會發生臟讀,不考慮。
  • Read Committed (RC) 針對當前讀,RC隔離級別保證對讀取到的記錄加鎖 (Gap Locking),存在幻讀現象。
  • Repeatable Read (RR) 針對當前讀,RR隔離級別保證對讀取到的記錄加鎖 (Record Locking),同時保證對讀取的范圍加鎖,新的滿足查詢條件的記錄不能夠插入 (Gap Locking),不存在幻讀現象。
  • Serializable 所有的讀操作均為退化為當前讀,讀寫沖突,因此并發度急劇下降,不考慮。

測試腳本

-- 基本操作 ---- 查詢事務隔離級別,默認是RRshow variables like '%isolation%';-- 設置事務隔離級別為RCset session transaction isolation level read committed;-- 數據初始化 --begin;drop table if exists user;CREATE TABLE `user` ( `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, `email` varchar(64) NOT NULL, `age` int(11) NOT NULL, `address` varchar(64) NOT NULL, PRIMARY KEY (`id`), UNIQUE KEY `uniq_email` (`email`), KEY `idx_age` (`age`));insert into user (email, age, address) values ("test1@elsef.com", 18, "address1");insert into user (email, age, address) values ("test2@elsef.com", 20, "address2");insert into user (email, age, address) values ("test3@elsef.com", 20, "address3");commit;select * from user;-- 一、trx_id示例begin;SELECT TRX_ID FROM INFORMATION_SCHEMA.INNODB_TRX WHERE TRX_MYSQL_THREAD_ID = CONNECTION_ID();select * from user;SELECT TRX_ID FROM INFORMATION_SCHEMA.INNODB_TRX WHERE TRX_MYSQL_THREAD_ID = CONNECTION_ID();SHOW ENGINE INNODB STATUS;update user set age = 22 where id = 3;-- 查詢事務idSELECT TRX_ID FROM INFORMATION_SCHEMA.INNODB_TRX WHERE TRX_MYSQL_THREAD_ID = CONNECTION_ID();-- INNODB 引擎狀態SHOW ENGINE INNODB STATUS;commit;-- 二、可重復讀、不可重復讀示例-- session1set session transaction isolation level read committed;begin;-- session2set session transaction isolation level repeatable read;begin;-- session1select * from user;-- session2select * from user;-- session3begin;insert into user (email, age, address) values ("test4@elsef.com", 30, "address4");commit;-- session1 這里因為是RC,所以可以讀到trx3提交的新數據,這里如果是證明不可重復讀的話應該使用update而不是insertselect * from user;commit;-- session2 這里因為是RR,所以不會讀到trx3提交的新數據select * from user;commit;-- 三、快照讀幻讀示例-- session1set session transaction isolation level repeatable read;begin;-- 這里使用快照讀select * from user;-- session2begin;insert into user (email, age, address) values ("test4@elsef.com", 30, "address4");commit;select * from user;-- session1select * from user; -- 這里讀不到test4@的數據,因為是RR-- 這里發生了幻讀insert into user (email, age, address) values ("test4@elsef.com", 30, "address4"); -- 插入失敗因為email唯一索引沖突commit;-- 四、當前讀幻讀示例-- RC-- session1set session transaction isolation level read committed;begin;-- 這里會對所有滿足條件的age=20的記錄加鎖,因為是RC,所以沒有GAP鎖delete from user where age = 20;select * from user;-- session2set session transaction isolation level read committed;begin;-- 因為trx1沒有加GAP鎖,所以之類可以插入age=20的記錄insert into user (email, age, address) values ("test4@elsef.com", 20, "address4");select * from user; -- 可以查到4條數據,可以讀到trx1的刪除數據,因為是RC,trx1未提交所以沒影響trx2commit;-- session1select * from user; -- 可以讀到trx2新插入的數據,雖然trx1是當前讀,但是并未添加相應的next-key鎖,沒有阻止trx2的新數據插入commit;--RR-- session1set session transaction isolation level repeatable read;begin;delete from user where age = 20;select * from user;-- session2begin;-- 這里會阻塞,因為trx1在age=20周圍加了GAP鎖-- 非唯一索引,首先,通過索引定位到第一條滿足查詢條件的記錄,加記錄上的X鎖,加GAP上的GAP鎖,然后加主鍵聚簇索引上的記錄X鎖;-- 然后讀取下一條,重復進行。直至進行到第一條不滿足條件的記錄,此時,不需要加記錄X鎖,但是仍舊需要加GAP鎖,最后返回結束。insert into user (email, age, address) values ("test4@elsef.com", 20, "address4");-- 直到超時,ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction-- 此時如果查詢可以看到3條記錄commit;-- session1-- 此時只能看到1條記錄,另外兩條被刪除了select * from user;commit;-- 唯一索引+RC-- session1set session transaction isolation level read committed;begin;delete from user where email = "test3@elsef.com";-- session2begin;-- 可以讀到,因為trx1是RCselect * from user where email = "test3@elsef.com";-- 嘗試更新這個記錄的age,會阻塞直到超時,因為email是唯一索引已經被trx1鎖住了,同時也會在對應的主鍵索引上加鎖-- 注意這里操作的id=3就是trx1中操作的email的同一行記錄update user set age = 40 where id = 3;-- session1commit;-- session2commit;-- 無索引+RC-- session1set session transaction isolation level read committed;begin;-- 由于address字段無索引,所以Innodb會對所有行進行加鎖,由MySQL server進行判斷并釋放鎖delete from user where address = "address3";-- session2set session transaction isolation level read committed;begin;-- 這一行會成功,因為這一行沒有加鎖(先加了后釋放了)update user set age = 10 where address = "address2";-- 這一行同樣會被阻塞,原因是它已經被trx1的語句加了鎖了,全部符合條件的都加鎖了update user set age = 10 where address = "address3";-- session1commit;-- session2commit;-- 非唯一索引+RR-- session1set session transaction isolation level repeatable read;begin;delete from user where age = 20;-- session2set session transaction isolation level repeatable read;begin;-- 這里會阻塞,因為trx1中已經鎖住了age=20的記錄以及加上了GAP鎖,所以這里18已經落入鎖區間insert into user (email, age, address) values ("test4@elsef.com", 18, "address4");-- session1commit;-- session2commit;-- 無索引RR-- session1set session transaction isolation level repeatable read;begin;-- 沒有索引,那么會鎖上表中的所有記錄,同時會鎖上主鍵索引上的所有GAP,杜絕所有的并發更新操作delete from user where address = "address3";-- session2set session transaction isolation level repeatable read;begin;-- 這里會阻塞,原因是主鍵已經被加上了GAP鎖,所以新的插入不能執行成功insert into user (email, age, address) values ("test4@elsef.com", 18, "address4");-- session1commit;-- session2commit;-- 死鎖 簡單示例-- session1begin;delete from user where id = 1;-- session2begin;delete from user where id = 3;-- session1delete from user where id = 3;-- seession2-- 這里MySQL判斷發生了死鎖,中斷了一個trx-- ERROR 1213 (40001): Deadlock found when trying to get lock; try restarting transactiondelete from user where id = 1;-- session1rollback;-- session2;rollback;-- 五、死鎖 insert示例drop table if exists t1;begin;create table t1 ( `id` bigint not null auto_increment, primary key (`id`));insert into t1 values(1);insert into t1 values(5);commit;select * from t1;-- session1begin;insert into t1 values (2);-- sessioin2begin;-- 這里會阻塞insert into t1 values (2);-- session3begin;-- 這里會阻塞insert into t1 values (2);-- session1;-- 此時回滾,trx2和trx3收到通知,MySQL自動中斷一個trx,因為發生了死鎖-- ERROR 1213 (40001): Deadlock found when trying to get lock; try restarting transactionrollback;--session2;rollback;--session3;rollback;

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲第一精品久久忘忧草社区| 国产精品h在线观看| 欧美日韩国产一区二区三区| 国产精品视频成人| 国产精品久久视频| 国产精品电影观看| 尤物精品国产第一福利三区| 国产精品一区二区三区在线播放| 欧美网站在线观看| 91久久久久久久| 国产精品精品视频一区二区三区| 97视频免费在线看| 欧美大片在线看| 欧美日韩国产综合视频在线观看中文| 久久精品视频导航| 欧美福利视频在线观看| 中文字幕国产亚洲2019| 欧美一级高清免费播放| 永久免费看mv网站入口亚洲| 18性欧美xxxⅹ性满足| 久久久电影免费观看完整版| 97在线看免费观看视频在线观看| 国产日韩一区在线| 欧美性开放视频| 欧美激情图片区| 久久精品成人一区二区三区| 亚洲精品小视频在线观看| 日韩成人在线网站| 欧美激情国产日韩精品一区18| 91视频免费在线| 狠狠做深爱婷婷久久综合一区| 国产午夜精品理论片a级探花| 国产精品视频xxxx| 97成人精品区在线播放| 国产成人精品日本亚洲专区61| 92国产精品久久久久首页| 午夜美女久久久久爽久久| 欧美日韩加勒比精品一区| 亚洲国产欧美精品| 性欧美暴力猛交69hd| 国产视频999| 午夜精品久久久久久久男人的天堂| 大量国产精品视频| 欧美精品中文字幕一区| 8x海外华人永久免费日韩内陆视频| 欧美裸体xxxx极品少妇| 日韩中文字幕在线免费观看| 久久久亚洲精品视频| 中日韩美女免费视频网址在线观看| 国内精品一区二区三区| 国产91|九色| 欧美日韩福利在线观看| 91香蕉国产在线观看| 欧美亚洲另类在线| 欧美日韩一区二区在线| 亚洲欧美国产va在线影院| 欧美精品videosex性欧美| 国产成人激情视频| 精品欧美激情精品一区| 日韩在线观看网址| 国产精品福利久久久| 欧美综合国产精品久久丁香| 国模私拍视频一区| 久久久久久久久久国产精品| 亚洲欧美一区二区三区情侣bbw| 亚洲美女视频网| 精品一区二区三区电影| 亚洲美女久久久| 91精品在线观看视频| 韩国精品美女www爽爽爽视频| 久久亚洲精品一区| 国内精品久久久久久| 日韩在线免费观看视频| 日韩在线欧美在线国产在线| 亚洲精品之草原avav久久| 欧美日韩免费区域视频在线观看| 亚洲黄色成人网| 美日韩丰满少妇在线观看| 两个人的视频www国产精品| 91精品国产91久久久久| 精品国产网站地址| 欧美亚洲一区在线| 欧美成人精品不卡视频在线观看| 欧美日韩一区二区三区| 国产成人亚洲精品| 亚洲最大av网站| 日韩免费av片在线观看| 欧美精品在线极品| 欧美有码在线观看视频| 91黑丝高跟在线| 精品中文字幕久久久久久| 91美女高潮出水| 91中文在线视频| 日韩免费看的电影电视剧大全| 亚洲欧洲在线免费| 国产精品久久久久aaaa九色| 国产精品观看在线亚洲人成网| 日韩欧美在线第一页| 国产成人精品视频| 国外成人在线播放| 国产精品18久久久久久麻辣| 国产精品美女主播在线观看纯欲| 国产精品久久激情| 精品免费在线观看| 97国产精品久久| 久久中文字幕在线视频| 日韩中文字幕网址| 国产精品第二页| 97在线视频一区| 奇米一区二区三区四区久久| 国产精品久久久久久久久久尿| 日韩av在线免播放器| 91干在线观看| 欧美日韩精品在线播放| 国产精品十八以下禁看| 成人激情视频在线观看| 奇米一区二区三区四区久久| 亚洲二区中文字幕| 欧美高清电影在线看| 91九色国产视频| 亚洲国产精品va在线看黑人动漫| 久久久伊人日本| 久久精品亚洲国产| 精品国产乱码久久久久久婷婷| 九九热r在线视频精品| 久久久久一本一区二区青青蜜月| 韩国视频理论视频久久| 日韩69视频在线观看| 欧美性受xxx| 亚洲激情视频在线| 亚洲人成在线观| 国产精品999| 精品在线小视频| 久久久亚洲影院| 久久精品中文字幕一区| 久久国产精品久久精品| 亚洲电影免费观看高清完整版| 欧美日韩中国免费专区在线看| 日韩成人xxxx| 国产999在线| 亚洲精品国精品久久99热一| 欧美孕妇孕交黑巨大网站| 亚洲成色999久久网站| 久久最新资源网| 欧美国产高跟鞋裸体秀xxxhd| 中文字幕亚洲精品| 亚洲性69xxxbbb| 国产精品欧美激情在线播放| 成人激情视频免费在线| 久久视频免费在线播放| 成人免费xxxxx在线观看| 大荫蒂欧美视频另类xxxx| 欧美国产日韩在线| 亚洲成色777777在线观看影院| 国产亚洲精品高潮| 色久欧美在线视频观看| 欧美福利视频在线| 亚洲一区二区三区四区在线播放| 91久久精品日日躁夜夜躁国产| 91成人免费观看网站| 国产精品午夜视频| 亚洲欧美精品中文字幕在线| 亚洲精选一区二区| 亚洲精选一区二区|