亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL中的行級(jí)鎖詳解

 更新時(shí)間:2025年03月03日 09:38:25   作者:WannaRunning  
MySQL中的行級(jí)鎖是InnoDB存儲(chǔ)引擎提供的一種細(xì)粒度鎖,基于索引實(shí)現(xiàn),MySQL中鎖有很多種,其中從鎖的粒度來(lái)區(qū)分的話可以分為表級(jí)鎖,行級(jí)鎖,頁(yè)級(jí)鎖,本文主要介紹MySQL中的行級(jí)鎖,感興趣的朋友一起看看吧

MySQL中鎖有很多種,其中從鎖的粒度來(lái)區(qū)分的話可以分為表級(jí)鎖,行級(jí)鎖,頁(yè)級(jí)鎖。

本文主要介紹下

行級(jí)鎖

MySQL中的行級(jí)鎖是MySQL中InnoDB存儲(chǔ)引擎提供的一種細(xì)粒度的鎖,基于索引實(shí)現(xiàn)的,鎖是加在索引上的,而不是數(shù)據(jù)行本身。

同樣是行級(jí)鎖,InnoDB存儲(chǔ)引擎對(duì)于其實(shí)現(xiàn)還可以細(xì)分為記錄鎖(Record Lock),間隙鎖(Gap Lock),臨鍵鎖(Next-Key Lock)和插入意向鎖(Insert Intention Lock)

記錄鎖(Record Lock)

記錄鎖也就是常說(shuō)的行鎖,顧名思義其鎖定的是某一行數(shù)據(jù)。

-- id = 1 的行會(huì)被加記錄排他鎖
update product_sale_record set sold_num = sold_num + 1 where id = 1;
-- id = 1 的行會(huì)被加共享鎖
select * from product_sale_record  where id = 1; LOCK IN SHARE MODE;

場(chǎng)景舉例

假設(shè)兩個(gè)事務(wù)A,B并發(fā)執(zhí)行下面的SQL:

start transaction;
update t_shop_product_sale_record set sold_num = sold_num +1 where id = 1;
commit;

當(dāng)事務(wù)A執(zhí)行 update 時(shí)會(huì)對(duì) id = 1 這行數(shù)據(jù)的排它鎖。

在事務(wù)A未提交的情況下,如果開(kāi)啟事務(wù)B執(zhí)行 update ,會(huì)出現(xiàn)鎖等待然后超時(shí):Lock wait timeout exceeded; try restarting transaction

間隙鎖(Gap Lock)

鎖定索引記錄之間的間隙,防止其他事務(wù)在范圍內(nèi)插入新數(shù)據(jù)。

-- id 在 1 和 10 之間的間隙會(huì)被加排他鎖。
update product_sale_record WHERE id > 1 AND id < 10;
-- id 在 1 和 10 之間的間隙會(huì)被加共享鎖。
select * from product_sale_record  WHERE id > 1 AND id < 10 LOCK IN SHARE MODE;

臨鍵鎖(Next-Key Lock)

臨鍵鎖可以理解為是記錄鎖和間隙鎖的組合,鎖定索引記錄及其前面的間隙。

-- id > 1 的記錄及其前面的間隙會(huì)被加排他鎖
update product_sale_record WHERE id > 1;
-- id > 1 的記錄及其前面的間隙會(huì)被加共享鎖
select * from product_sale_record where id > 1 LOCK IN SHARE MODE;

到此這篇關(guān)于MySQL中的行級(jí)鎖的文章就介紹到這了,更多相關(guān)mysql行級(jí)鎖內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL索引下推的深入探索

    MySQL索引下推的深入探索

    這篇文章主要介紹了MySQL的索引下推,索引下推是為了解決在過(guò)濾條件時(shí),可能導(dǎo)致大量的數(shù)據(jù)行被檢索出來(lái),但實(shí)際上只有很少的行滿足WHERE子句中的所有條件的情況,需要的朋友可以參考下
    2022-07-07
  • mysql use命令選擇數(shù)據(jù)庫(kù)詳解

    mysql use命令選擇數(shù)據(jù)庫(kù)詳解

    這篇文章主要介紹了mysql 使用use命令選擇數(shù)據(jù)庫(kù)的相關(guān)資料,需要的朋友可以參考下
    2016-09-09
  • MySQL如何修改字段類型和字段長(zhǎng)度

    MySQL如何修改字段類型和字段長(zhǎng)度

    這篇文章主要介紹了MySQL如何修改字段類型和字段長(zhǎng)度,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • 數(shù)據(jù)庫(kù)sql語(yǔ)句優(yōu)化

    數(shù)據(jù)庫(kù)sql語(yǔ)句優(yōu)化

    今天小編就為大家分享一篇關(guān)于數(shù)據(jù)庫(kù)sql語(yǔ)句優(yōu)化,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-01-01
  • 解析MySQL?join查詢的原理

    解析MySQL?join查詢的原理

    這篇文章主要介紹了MySQL?join查詢的原理,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-01-01
  • mysql中g(shù)eneral_log日志知識(shí)點(diǎn)介紹

    mysql中g(shù)eneral_log日志知識(shí)點(diǎn)介紹

    這篇文章主要介紹了mysql中g(shù)eneral_log日志知識(shí)點(diǎn)的介紹以及其他相關(guān)內(nèi)容,以后興趣的朋友們學(xué)習(xí)下。
    2019-08-08
  • CenOS6.7下mysql 8.0.22 安裝配置方法圖文教程

    CenOS6.7下mysql 8.0.22 安裝配置方法圖文教程

    這篇文章主要為大家詳細(xì)介紹了CenOS6.7下mysql 8.0.22 安裝配置方法圖文教程,文中安裝步驟介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • MySQL中TINYINT、INT 和 BIGINT的具體使用

    MySQL中TINYINT、INT 和 BIGINT的具體使用

    MySQL提供了多種整數(shù)類型來(lái)滿足不同的數(shù)據(jù)存儲(chǔ)需求,本文主要介紹了MySQL中TINYINT、INT 和 BIGINT的具體使用,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-07-07
  • MySQL在不知道列名情況下的注入詳解

    MySQL在不知道列名情況下的注入詳解

    這篇文章主要給大家介紹了關(guān)于MySQL在不知道列名情況下的注入的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用mysql具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • MySQL表分區(qū)的幾種實(shí)現(xiàn)

    MySQL表分區(qū)的幾種實(shí)現(xiàn)

    本文主要介紹了MySQL表分區(qū)的幾種實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08

最新評(píng)論