婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MySQL 鎖的相關(guān)知識總結(jié)

MySQL 鎖的相關(guān)知識總結(jié)

熱門標(biāo)簽:啥是企業(yè)400電話辦理 南昌三維地圖標(biāo)注 外呼系統(tǒng)打電話上限是多少 曲靖移動(dòng)外呼系統(tǒng)公司 怎樣在地圖標(biāo)注銷售區(qū)域 武漢網(wǎng)絡(luò)外呼系統(tǒng)服務(wù)商 地圖標(biāo)注費(fèi)用是多少 電話外呼系統(tǒng)改號 百應(yīng)電話機(jī)器人優(yōu)勢

MySQL中的鎖

鎖是為了解決并發(fā)環(huán)境下資源競爭的手段,其中樂觀并發(fā)控制,悲觀并發(fā)控制和多版本并發(fā)控制是數(shù)據(jù)庫并發(fā)控制主要采用的技術(shù)手段(具體可見我之前的文章),而MySQL中的鎖就是其中的悲觀并發(fā)控制。

MySQL中的鎖有很多種類,我們可以按照下面方式來進(jìn)行分類。

按讀寫

從數(shù)據(jù)庫的讀寫的角度來分,數(shù)據(jù)庫的鎖可以分為分為以下幾種:

  • 獨(dú)占鎖:又稱排它鎖、X鎖、寫鎖。X鎖不能和其他鎖兼容,只要有事務(wù)對數(shù)據(jù)上加了任何鎖,其他事務(wù)就不能對這些數(shù)據(jù)再放置X了,同時(shí)某個(gè)事務(wù)放置了X鎖之后,其他事務(wù)就不能再加其他任何鎖了,只有獲取排他鎖的事務(wù)是可以對數(shù)據(jù)進(jìn)行讀取和修改。
  • 共享鎖:又稱讀鎖、S鎖。S鎖與S鎖兼容,可以同時(shí)放置。
  • 更新鎖:又稱U鎖。它允許再加S鎖,但不允許其他事務(wù)再施加U鎖或X鎖,當(dāng)被讀取的數(shù)據(jù)要被更新時(shí),則升級S鎖為X鎖。U鎖的優(yōu)點(diǎn)是允許事務(wù)A讀取數(shù)據(jù)的同時(shí)不阻塞其它事務(wù),并同時(shí)確保事務(wù)A自從上次讀取數(shù)據(jù)后數(shù)據(jù)沒有被更改,因此可以減少X鎖和S鎖的沖突,同時(shí)避免使用S鎖后再升級為X鎖造成的死鎖現(xiàn)象。注意,MySQL并不支持U鎖,SQLServer才支持U鎖。

兼容性矩陣如下(+ 代表兼容, -代表不兼容)

右側(cè)是已加的鎖 X S U
X - - -
S - + +
U - + -

按粒度

MySQL支持不同級別的鎖,其鎖定的數(shù)據(jù)的范圍也不同,也即我們常說的鎖的粒度。MySQL有三種鎖級別:行級鎖、頁級鎖、表級鎖。不同的存儲(chǔ)引擎支持不同的鎖粒度,例如MyISAM和MEMORY存儲(chǔ)引擎采用的是表級鎖,頁級鎖僅被BDB存儲(chǔ)引擎支持,InnoDB存儲(chǔ)引擎支持行級鎖和表級鎖,默認(rèn)情況下是采用行級鎖。

特點(diǎn)

表級鎖:開銷小,加鎖快;不會(huì)出現(xiàn)死鎖;鎖定粒度大,發(fā)生鎖沖突的概率最高,并發(fā)度最低。數(shù)據(jù)庫引擎總是一次性同時(shí)獲取所有需要的鎖以及總是按相同的順序獲取表鎖從而避免死鎖。
行級鎖:開銷大,加鎖慢;會(huì)出現(xiàn)死鎖;鎖定粒度最小,發(fā)生鎖沖突的概率最低,并發(fā)度也最高。行鎖總是逐步獲得的,因此會(huì)出現(xiàn)死鎖。
頁面鎖:開銷和加鎖時(shí)間界于表鎖和行鎖之間;會(huì)出現(xiàn)死鎖;鎖定粒度界于表鎖和行鎖之間,并發(fā)度一般。

下面詳細(xì)介紹行鎖和表鎖,頁鎖由于使用得較少就不介紹了。

行鎖

按行對數(shù)據(jù)進(jìn)行加鎖。InnoDB行鎖是通過給索引上的索引項(xiàng)加鎖來實(shí)現(xiàn)的,Innodb一定存在聚簇索引,行鎖最終都會(huì)落到聚簇索引上,通過非聚簇索引查詢的時(shí)候,先鎖非聚簇索引,然后再鎖聚簇索引。如果一個(gè)where語句里面既有聚簇索引,又有二級索引,則會(huì)先鎖聚簇索引,再鎖二級索引。由于是分步加鎖的,因此可能會(huì)有死鎖發(fā)生。

MySQL的行鎖對S、X鎖上做了一些更精確的細(xì)分,使得行鎖的粒度更細(xì)小,可以減少?zèng)_突,這就是被稱為“precise mode”的兼容矩陣。(該矩陣沒有出現(xiàn)在官方文檔上,是有人通過Mysql lock0lock.c:lock_rec_has_to_wait源代碼推測出來的。)

行鎖兼容矩陣

  • 間隙鎖(Gap Lock):只鎖間隙,前開后開區(qū)間(a,b),對索引的間隙加鎖,防止其他事務(wù)插入數(shù)據(jù)。
  • 記錄鎖(Record Lock):只鎖記錄,特定幾行記錄。
  • 臨鍵鎖(Next-Key Lock):同時(shí)鎖住記錄和間隙,前開后閉區(qū)間(a,b]。
  • 插入意圖鎖(Insert Intention Lock):插入時(shí)使用的鎖。在代碼中,插入意圖鎖,實(shí)際上是GAP鎖上加了一個(gè)LOCK_INSERT_INTENTION的標(biāo)記。

右側(cè)是已加的鎖(+ 代表兼容, -代表不兼容) G R N I
G + + + +
R + +
N + +
I + +

S鎖和S鎖是完全兼容的,因此在判別兼容性時(shí)不需要對比精確模式。精確模式的檢測,用在S、X和X、X之間。從這個(gè)矩陣可以看到幾個(gè)特點(diǎn):

  • INSERT操作之間不會(huì)有沖突:你插入你的,我插入我的。
  • GAP,Next-Key會(huì)阻止Insert:插入的數(shù)據(jù)正好在區(qū)間內(nèi),不允許插入。
  • GAP和Record,Next-Key不會(huì)沖突
  • Record和Record、Next-Key之間相互沖突。
  • 已有的Insert鎖不阻止任何準(zhǔn)備加的鎖。
  • 間隙鎖(無論是S還是X)只會(huì)阻塞insert操作。

注意點(diǎn)

  • 對于記錄鎖,列必須是唯一索引列或者主鍵列,查詢語句必須為精確匹配,如“=”,否則記錄鎖會(huì)退化為臨鍵鎖。
  • 間隙鎖和臨鍵鎖基于非唯一索引,在唯一索引列上不存在間隙鎖和臨鍵鎖。

表鎖與鎖表的誤區(qū)

只有正確通過索引條件檢索數(shù)據(jù)(沒有索引失效的情況),InnoDB才會(huì)使用行級鎖,否則InnoDB對表中的所有記錄加鎖,也就是將鎖住整個(gè)表。注意,這里說的是鎖住整個(gè)表,但是Innodb并不是使用表鎖來鎖住表的,而是使用了下面介紹的Next-Key Lock來鎖住整個(gè)表。網(wǎng)上很多的說法都是說用表鎖,然而實(shí)際上并不是,我們可以通過下面的例子來看看。

假設(shè)我們有以下的數(shù)據(jù)(MySQL8):

mysql> select * from users;
+----+------+-----+
| id | name | age |
+----+------+-----+
| 1 | a  | 1  |
| 2 | a  | 1  |
| 3 | a  | 1  |
| 4 | a  | 1  |
| 5 | a  | 1  |
+----+------+-----+

方法一:

我們使用表鎖鎖表,并查看引擎的狀態(tài)

mysql> begin;
Query OK, 0 rows affected (0.00 sec)

mysql> lock tables users write;
Query OK, 0 rows affected (0.00 sec)

mysql> show engine innodb status\G
...
------------
TRANSACTIONS
------------
Trx id counter 4863
Purge done for trx's n:o  4862 undo n:o  0 state: running but idle
History list length 911
LIST OF TRANSACTIONS FOR EACH SESSION:
---TRANSACTION 281479760456232, not started
mysql tables in use 1, locked 1  ###############注意這里
0 lock struct(s), heap size 1136, 0 row lock(s)
...

然后我們再通過非索引的字段查詢來加鎖,并查看引擎的狀態(tài)

## 先解鎖上次的表鎖
mysql> unlock tables;
Query OK, 0 rows affected (0.00 sec)

mysql> commit;
Query OK, 0 rows affected (0.00 sec)

mysql> begin;
Query OK, 0 rows affected (0.00 sec)

mysql> select * from users where name = 'a' for update;

mysql> show engine innodb status\G
...
------------
TRANSACTIONS
------------
Trx id counter 4864
Purge done for trx's n:o  4862 undo n:o  0 state: running but idle
History list length 911
LIST OF TRANSACTIONS FOR EACH SESSION:
---TRANSACTION 4863, ACTIVE 37 sec
2 lock struct(s), heap size 1136, 6 row lock(s)  ###############注意這里
...

然后我們再刪除id為2,3,4的數(shù)據(jù),然后在通過非索引的字段查詢來加鎖,并查看引擎的狀態(tài)

mysql> delete from users where id in (2,3,4);
Query OK, 3 rows affected (0.00 sec)

mysql> commit;
Query OK, 0 rows affected (0.00 sec)

mysql> begin;
Query OK, 0 rows affected (0.00 sec)

mysql> select * from users where name = 'a' for update;

mysql> show engine innodb status\G
...
------------
TRANSACTIONS
------------
Trx id counter 4870
Purge done for trx's n:o  4869 undo n:o  0 state: running but idle
History list length 914
LIST OF TRANSACTIONS FOR EACH SESSION:
---TRANSACTION 4869, ACTIVE 9 sec
2 lock struct(s), heap size 1136, 3 row lock(s)  ###############注意這里
...

可以看到這里使用了表鎖和因?yàn)闆]法用索引鎖定特定行而轉(zhuǎn)而鎖住整個(gè)表是不一樣的。從第二次和第三次的操作來看,lock住的row也是不同的,這是因?yàn)閮烧唛g隙的個(gè)數(shù)不同,所以可以看到使用的并不是表鎖,而是Next-Key Lock。第一次鎖住了(-∞,1],(1,2],(2,3],(3,4],(4,5],(5,∞],第二次鎖住了(-∞,1],(1,5],(5,∞]。

方法二:

也可以通過以下語句來查看鎖的信息,也可以知道用的是行鎖,且是鎖住了區(qū)間(插入不了數(shù)據(jù))和記錄,所以是Next-Key Lock。

mysql> select ENGINE_TRANSACTION_ID,LOCK_TYPE,LOCK_MODE from performance_schema.data_locks where ENGINE_TRANSACTION_ID in (你的事務(wù)id);
+-----------------------+-----------+-----------+
| ENGINE_TRANSACTION_ID | LOCK_TYPE | LOCK_MODE |
+-----------------------+-----------+-----------+
|         4889 | TABLE   | IX    |
|         4889 | RECORD  | X     |
|         4889 | RECORD  | X     |
|         4889 | RECORD  | X     |
+-----------------------+-----------+-----------+
10 rows in set (0.00 sec)

LOCK_TYPE:對于InnoDB,可選值為 RECORD(行鎖), TABLE(表鎖)

LOCK_MODE:對于InnoDB,可選值為S[,GAP], X[,GAP], IS[,GAP],IX[,GAP], AUTO_INC和UNKNOWN。除了AUTO_INC和UNKNOWN,其他鎖定模式都包含了GAP鎖(如果存在)。

具體可見 MySQL文檔:https://dev.mysql.com/doc/ref...

表級鎖

直接對整個(gè)表加鎖,影響表中所有記錄,表讀鎖和表寫鎖的兼容性見上面的分析。

MySQL中除了表讀鎖和表寫鎖之外,還存在一種特殊的表鎖:意向鎖,這是為了解決不同粒度的鎖的兼容性判斷而存在的。

意向鎖

因?yàn)殒i的粒度不同,表鎖的范圍覆蓋了行鎖的范圍,所以表鎖和行鎖會(huì)產(chǎn)生沖突,例如事務(wù)A對表中某一行數(shù)據(jù)加了行鎖,然后事務(wù)B想加表鎖,正常來說是應(yīng)該要沖突的。如果只有行鎖的話,要判斷是否沖突就得遍歷每一行數(shù)據(jù)了,這樣的效率實(shí)在不高,因此我們就有了意向表鎖。

意向鎖的主要目的是為了使得 行鎖 和 表鎖 共存,事務(wù)在申請行鎖前,必須先申請表的意向鎖,成功后再申請行鎖。注意:申請意向鎖的動(dòng)作是數(shù)據(jù)庫完成的,不需要開發(fā)者來申請。

意向鎖是表級鎖,但是卻表示事務(wù)正在讀或?qū)懩骋恍杏涗洠皇钦麄€(gè)表, 所以意向鎖之間不會(huì)產(chǎn)生沖突,真正的沖突在加行鎖時(shí)檢查。

意向鎖分為意向讀鎖(IS)和意向?qū)戞i(IX)。

表鎖的兼容性矩陣

右側(cè)是已加的鎖(+ 代表兼容, -代表不兼容) IS IX S X
IS + + +
IX + +
S + +
X

以上就是MySQL 鎖的相關(guān)知識總結(jié)的詳細(xì)內(nèi)容,更多關(guān)于MySQL 鎖的資料請關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • Mysql事務(wù)中Update是否會(huì)鎖表?
  • MySQL數(shù)據(jù)庫鎖機(jī)制原理解析
  • mysql查看死鎖與去除死鎖示例詳解
  • MySQL死鎖檢查處理的正常方法
  • mysql查詢表是否被鎖的方法
  • 通過實(shí)例判斷mysql update是否會(huì)鎖表
  • MySQL中的悲觀鎖與樂觀鎖
  • MySQL 行鎖和表鎖的含義及區(qū)別詳解
  • mysql 悲觀鎖與樂觀鎖的理解及應(yīng)用分析
  • MySQL 8.0.19支持輸入3次錯(cuò)誤密碼鎖定賬戶功能(例子)

標(biāo)簽:黑河 吉林 錦州 滄州 隨州 資陽 甘南 荊州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL 鎖的相關(guān)知識總結(jié)》,本文關(guān)鍵詞  MySQL,鎖,的,相關(guān),知識,總結(jié),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL 鎖的相關(guān)知識總結(jié)》相關(guān)的同類信息!
  • 本頁收集關(guān)于MySQL 鎖的相關(guān)知識總結(jié)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    在线观看视频一区二区| 国产精品久久一卡二卡| 国产精选一区二区三区| 4438x亚洲最大成人网| 激情六月婷婷久久| 亚洲国产高清不卡| 大陆成人av片| 亚洲免费观看在线观看| 蜜桃视频在线观看一区| 1000精品久久久久久久久| 91蝌蚪国产九色| 国产成+人+日韩+欧美+亚洲| 欧美国产一区二区| 精品久久久久香蕉网| 欧美日韩在线播| 欧美日韩一区二区在线观看| 91色九色蝌蚪| 99久久er热在这里只有精品66| 天堂久久一区二区三区| 亚洲影院理伦片| 午夜精品视频一区| 麻豆久久久久久久| 久久99最新地址| 国产乱码精品1区2区3区| 国产精品911| 国产天堂亚洲国产碰碰| 综合久久久久综合| av高清久久久| 人人狠狠综合久久亚洲| 欧美精品在线视频| 亚洲一区二区三区精品在线| 亚洲天堂网中文字| 久久婷婷综合激情| 国产精品国产三级国产普通话三级| 日韩欧美一区二区在线视频| 欧美福利一区二区| 日韩欧美的一区二区| 久久久久久亚洲综合影院红桃 | 亚洲人成精品久久久久| 欧美人xxxx| 欧美久久高跟鞋激| 91麻豆精品秘密| 久久精品国产亚洲aⅴ| 亚洲午夜在线电影| 亚洲精选一二三| 亚洲色图视频免费播放| 国产精品夫妻自拍| 亚洲免费av在线| 亚洲视频一区二区免费在线观看| 欧美日韩视频在线观看一区二区三区 | 中文字幕一区二区5566日韩| 午夜欧美电影在线观看| 精品亚洲porn| 欧美电视剧在线看免费| 国产三级一区二区三区| 欧美成人乱码一区二区三区| 色噜噜夜夜夜综合网| 免费日本视频一区| 久久黄色级2电影| 国产在线精品一区二区夜色| 91精品婷婷国产综合久久| 视频一区在线播放| 久久精品国产99国产精品| 国产精品久久久一本精品| 亚洲国产精品视频| 欧美韩国一区二区| 精品入口麻豆88视频| 欧美一卡二卡三卡| 久久精品国产亚洲a| 国产精品看片你懂得| 日欧美一区二区| 91网页版在线| 精品久久久网站| 亚洲激情一二三区| av高清久久久| 国产欧美日韩在线| 国产99久久久国产精品免费看| 成人性生交大片免费看中文| 欧美巨大另类极品videosbest | 成人午夜视频免费看| 国产日韩高清在线| 波多野结衣中文字幕一区二区三区| 午夜免费欧美电影| 国产免费久久精品| 国产麻豆午夜三级精品| 亚洲日本护士毛茸茸| 亚洲精品一区二区三区99| 亚洲九九爱视频| 91国偷自产一区二区三区成为亚洲经典| 日韩一区二区视频| 青青草国产成人99久久| 日韩欧美国产三级电影视频| 日本伊人精品一区二区三区观看方式 | 综合婷婷亚洲小说| 亚洲午夜在线视频| 亚洲一区二区三区四区的| 日本91福利区| 成人激情免费网站| 亚洲国产综合91精品麻豆| 欧美裸体一区二区三区| 国产精品一区二区在线看| 亚洲国产精品黑人久久久| 一区二区三区四区乱视频| 欧美一二三区精品| 国产成人在线视频免费播放| 亚洲精品老司机| 欧洲精品一区二区三区在线观看| 一区二区三区免费观看| 日韩欧美国产一区二区在线播放| 91免费国产在线观看| 欧美日韩国产大片| 欧美日韩高清一区| 国产欧美久久久精品影院| 国产精品乱人伦| 日韩欧美在线不卡| 91麻豆精品国产91久久久资源速度| 91蜜桃免费观看视频| 日韩电影在线一区二区| 国产精品久久三| 国产精品天干天干在线综合| 亚洲男人的天堂av| 国产精品久久网站| 国产女人18水真多18精品一级做| 在线视频中文字幕一区二区| 亚洲五码中文字幕| 综合色天天鬼久久鬼色| 亚洲成av人影院在线观看网| 亚洲国产成人av网| 亚洲6080在线| 午夜精品一区二区三区三上悠亚| 中文字幕一区二区三区四区不卡| 国产网红主播福利一区二区| 欧美激情一区二区三区全黄 | 自拍偷在线精品自拍偷无码专区| 欧美日韩精品福利| 欧美成人r级一区二区三区| 久久看人人爽人人| 一区二区在线观看视频在线观看| 国产一区啦啦啦在线观看| 欧美亚洲高清一区| 久久蜜桃一区二区| 日韩黄色一级片| 欧美午夜精品久久久久久超碰 | 亚洲三级在线播放| 美女免费视频一区二区| 91久久久免费一区二区| 国产精品夫妻自拍| 国产宾馆实践打屁股91| 欧美一级淫片007| 日本午夜一本久久久综合| 99re66热这里只有精品3直播| 精品久久久久av影院 | 国产午夜精品一区二区三区视频| 日日骚欧美日韩| 91麻豆自制传媒国产之光| 亚洲精品国产无天堂网2021| 色婷婷久久久久swag精品| 国产精品毛片a∨一区二区三区| 成人少妇影院yyyy| 精品国产凹凸成av人导航| 卡一卡二国产精品 | 国产欧美日韩亚州综合| 国产精品久久久久一区二区三区| 欧美一区二区黄色| 555夜色666亚洲国产免| 亚洲一区二区成人在线观看| 色88888久久久久久影院野外| 日韩av电影免费观看高清完整版| 欧美成人aa大片| 丁香婷婷深情五月亚洲| 一区二区三区在线视频观看| 99精品视频一区二区三区| 亚洲线精品一区二区三区八戒| 九色porny丨国产精品| 国产午夜亚洲精品羞羞网站| 欧美色手机在线观看| 国产一区三区三区| 日韩一区精品字幕| 亚洲尤物在线视频观看| 国产精品久久久久毛片软件| 欧美日韩一级大片网址| 成人午夜在线播放| 成人性生交大片免费看视频在线| 老司机精品视频一区二区三区| 亚洲影院久久精品| 亚洲色图视频网站| 一区在线中文字幕| 久久九九久久九九| 国产精品久久久久久妇女6080| 欧美成人一区二区三区片免费| 色综合久久久久综合| 成人av网站大全| av亚洲产国偷v产偷v自拍| 99re6这里只有精品视频在线观看| 99久久99久久久精品齐齐| 97久久人人超碰| 色婷婷综合久久久中文一区二区| 国产成人精品在线看| 8x福利精品第一导航| 国产精品久久夜|