成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

MySQL 啥時候用表鎖,啥時候用行鎖?

開發(fā) 前端
對于表鎖而言,當(dāng)存儲引擎不支持行級鎖時,使用表鎖。SQL 語句沒有匹配到索引時,使用表鎖。對于元數(shù)據(jù)鎖而言,對表做增刪改查時,會加上 MDL 讀鎖。對表結(jié)構(gòu)做變更時,會加上 MDL 寫鎖。對于意向鎖而言,對表中的行記錄加鎖時,會用到意向鎖。

大家好,我是樹哥。

MySQL Innodb 的鎖可以說是執(zhí)行引擎的并發(fā)基礎(chǔ)了,有了鎖才能保證數(shù)據(jù)的一致性。眾所周知,我們都知道 Innodb 有全局鎖、表級鎖、行級鎖三種,但你知道什么時候會用表鎖,什么時候會用行鎖嗎?

雖然對 MySQL 的知識點挺熟悉的,但一開始看到這個問題,樹哥也是有點懵,我還真沒從這個角度去思考過。大家可以暫時 1 分鐘思考下答案,后面我將帶大家弄清楚這個問題。

對于這個問題,我只能粗略地想起一些片段,例如:

  • 對于表級鎖而言,當(dāng)執(zhí)行 DDL 語句去修改表結(jié)構(gòu)時,會使用表級鎖。
  • 對于行級鎖而言,一般情況下都會默認使用行級鎖,貌似是需要有索引匹配到才行。

上面就是我粗略想到的答案,不知道大家思考的答案是否和我一樣呢?下面就讓我?guī)е蠹襾頊亓?xí)下 MySQL 的鎖吧!

圖片

文章思維導(dǎo)圖

對于數(shù)據(jù)庫而言,其鎖范圍可以分為:

  • 全局鎖
  • 表級鎖
  • 行級鎖

全局鎖

全局鎖就是對整個數(shù)據(jù)庫實例加鎖。 MySQL 提供了一個加全局讀鎖的方法,命令是 Flush tables with read lock (FTWRL)。當(dāng)你需要讓整個庫處于只讀狀態(tài)的時候,可以使用這個命令,之后其他線程的以下語句會被阻塞:數(shù)據(jù)更新語句(數(shù)據(jù)的增刪改)、數(shù)據(jù)定義語句(包括建表、修改表結(jié)構(gòu)等)和更新類事務(wù)的提交語句。你可以理解為,全局鎖基本上把數(shù)據(jù)所所有的變更語句都鎖住了。

全局鎖的典型場景應(yīng)用場景是全庫邏輯備份,也就是把整個庫每個表都 select 出來存起來。上面說到全局鎖會鎖住所有變更語句,但這只是對于 MyISAM 存儲引擎而言的。對于 Innodb 而言,其可以利用 MVCC 實現(xiàn)數(shù)據(jù)的一致性視圖,從而不需要鎖整個庫就可以實現(xiàn)全庫的數(shù)據(jù)備份。

表級鎖

表級鎖可以分為:表鎖、元數(shù)據(jù)鎖、意向鎖三種。

表鎖

表鎖,顧名思義就是對某個表加鎖。

那什么時候會使用表鎖呢?

一般情況是對應(yīng)的存儲引擎沒有行級鎖(例如:MyIASM),或者是對應(yīng)的 SQL 語句沒有匹配到索引。

對于第一種情況而言,因為對應(yīng)存儲引擎不支持行鎖,所以只能是使用更粗粒度的鎖來實現(xiàn),這也比較好理解。

對于第二種情況而言,如果存儲引擎支持行鎖,但對應(yīng)的 SQL 就沒有使用索引,那么此時也是會全表掃描,那此時也是會使用表鎖。例如下面的語句沒有指定查詢列,或者指定了查詢列但是并沒有用到索引,那么也是會直接鎖定整個表。

// 沒有指定查詢列
select * from user;
// 指定查詢列,但是沒有用到索引
select * from user where name = 'zhangsan';

上面說的索引,可以說是判斷是否會用行級鎖的關(guān)鍵。但我想到一個問題:如果查詢或更新用到了索引,但是查詢或更新的數(shù)據(jù)特別多,占全表的 80% 甚至更多,這時候是會用表鎖,還是行鎖呢? 這是一個很有意思的問題,感興趣的朋友自行弄個測試表驗證一下,后續(xù)有機會我們再聊聊這個問題。

元數(shù)據(jù)鎖

元數(shù)據(jù),指的是我們的表結(jié)構(gòu)這些元數(shù)據(jù)。元數(shù)據(jù)鎖(Metadata Lock)自然是執(zhí)行 DDL 表結(jié)構(gòu)變更語句時,我們對表加上的一個鎖了。

那什么時候會使用元數(shù)據(jù)鎖這個表級鎖呢?

當(dāng)我們對一個表做增刪改查操作的時候,會加上 MDL 讀鎖;當(dāng)我們要對表結(jié)構(gòu)做變更時,就會加 MDL 寫鎖。

意向鎖

意向鎖,本質(zhì)上就是空間換時間的產(chǎn)物,是為了提高行鎖效率的一個東西。

在 InnoDB 中,我們對某條記錄進行鎖定時,為了提高并發(fā)度,通常都只是鎖定這一行記錄,而不是鎖定整個表。而當(dāng)我們需要為整個表加 X 鎖的時候,我們就需要遍歷整個表的記錄,如果每條記錄都沒有被加鎖,才可以給整個表加 X 鎖。而這個遍歷過程就很費時間,這時候就有了意向鎖的誕生。

意向鎖其實就是標(biāo)記這個表有沒有被鎖,如果有某條記錄被鎖住了,那么就必須獲取該表的意向鎖。所以當(dāng)我們需要判斷這個表的記錄有沒有被加鎖時,直接判斷意向鎖就可以了,減少了遍歷的時間,提高了效率,是典型的用空間換時間的做法。

那么什么時候會用到意向鎖呢?

很簡單,就是在對表中的行記錄加鎖的時候,就會用到意向鎖。

行級鎖

千呼萬喚,終于來到了行級鎖。

要知道的是,行級鎖是存儲引擎級別的鎖,需要存儲引擎支持才有效。目前 MyISAM 存儲引擎不支持行級鎖,而 Innodb 存儲引擎則支持行級鎖。而全局鎖、表級鎖,則是 MySQL 層面就支持的鎖。

那么什么時候會使用行級鎖呢?

當(dāng)增刪改查匹配到索引時,Innodb 會使用行級鎖。

如果沒有匹配不到索引,那么就會直接使用表級鎖。

總結(jié)

文章最后,我們回顧一下開頭提出的問題:Innodb 啥時候用表鎖,啥時候用行鎖?

表級鎖包括:表鎖、元數(shù)據(jù)鎖、意向鎖。

對于表鎖而言,當(dāng)存儲引擎不支持行級鎖時,使用表鎖。SQL 語句沒有匹配到索引時,使用表鎖。

對于元數(shù)據(jù)鎖而言,對表做增刪改查時,會加上 MDL 讀鎖。對表結(jié)構(gòu)做變更時,會加上 MDL 寫鎖。

對于意向鎖而言,對表中的行記錄加鎖時,會用到意向鎖。

而對于行級鎖而言,增刪改查匹配到索引時,會使用行級鎖。

最后,附上本文的思維導(dǎo)圖,方便大家回顧本文內(nèi)容。

圖片

文章思維導(dǎo)圖

責(zé)任編輯:武曉燕 來源: 樹哥聊編程
相關(guān)推薦

2022-10-24 08:02:14

MySQL索引類型

2020-01-15 07:43:45

架構(gòu)redis開發(fā)

2024-11-29 07:38:12

MySQL數(shù)據(jù)庫

2021-12-26 00:48:05

一致性視圖數(shù)據(jù)庫

2025-02-10 09:58:48

2019-08-23 07:58:51

GDPR安全隱私數(shù)據(jù)安全

2020-10-20 13:50:47

MySQL數(shù)據(jù)庫

2010-05-24 12:50:59

MySQL表級鎖

2023-11-06 08:35:08

表鎖行鎖間隙鎖

2024-05-20 09:58:27

2024-03-04 00:01:00

鎖表鎖行MySQL

2018-07-31 10:10:06

MySQLInnoDB死鎖

2024-06-14 09:27:00

2022-10-24 00:33:59

MySQL全局鎖行級鎖

2024-08-07 14:58:00

MySQL釋放鎖核心模塊

2015-07-08 15:55:01

NSStringcopystrong

2024-08-09 09:00:00

Akamai云服務(wù)

2020-02-06 10:02:45

MySQL數(shù)據(jù)庫全局鎖

2021-06-07 07:59:37

MySQL 全局鎖線程

2025-06-04 02:55:00

MySQL意向鎖記錄鎖
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 亚洲视频一区在线 | 中文字幕在线播放第一页 | 国产91视频一区二区 | 亚洲精品久久久久久久久久久 | 另类视频区 | 久久高清 | 成人一区二区三区视频 | 久久亚洲国产 | 国产乱码久久久久久一区二区 | 精品一区二区在线观看 | 男人天堂999 | 国产乱码精品1区2区3区 | 日韩av免费在线观看 | 一区二区精品视频 | 亚洲综合国产 | 国产精品久久久久久福利一牛影视 | 免费高潮视频95在线观看网站 | 日韩亚洲一区二区 | 成人福利 | 欧产日产国产精品国产 | 亚洲一区视频在线 | 成人av播放 | 欧美视频一区 | 亚洲伊人a| 国产在线一区二区三区 | 亚洲免费婷婷 | 久久综合成人精品亚洲另类欧美 | 久久毛片| 国产一区二区三区四区hd | 欧美做暖暖视频 | 欧美激情精品久久久久久免费 | 欧美性受 | 国产美女自拍视频 | 成人a在线 | 亚洲欧美另类在线观看 | 91精品国产综合久久久动漫日韩 | 免费观看毛片 | 91麻豆精品国产91久久久久久 | 欧美日韩精品影院 | 国产美女h视频 | 久久精品无码一区二区三区 |