MySQL中的行級鎖詳解
MySQL中鎖有很多種,其中從鎖的粒度來區(qū)分的話可以分為表級鎖,行級鎖,頁級鎖。
本文主要介紹下
行級鎖
MySQL中的行級鎖是MySQL中InnoDB存儲引擎提供的一種細粒度的鎖,基于索引實現(xiàn)的,鎖是加在索引上的,而不是數(shù)據(jù)行本身。
同樣是行級鎖,InnoDB存儲引擎對于其實現(xiàn)還可以細分為記錄鎖(Record Lock),間隙鎖(Gap Lock),臨鍵鎖(Next-Key Lock)和插入意向鎖(Insert Intention Lock)。
記錄鎖(Record Lock)
記錄鎖也就是常說的行鎖,顧名思義其鎖定的是某一行數(shù)據(jù)。
-- id = 1 的行會被加記錄排他鎖 update product_sale_record set sold_num = sold_num + 1 where id = 1; -- id = 1 的行會被加共享鎖 select * from product_sale_record where id = 1; LOCK IN SHARE MODE;
場景舉例
假設兩個事務A,B并發(fā)執(zhí)行下面的SQL:
start transaction; update t_shop_product_sale_record set sold_num = sold_num +1 where id = 1; commit;
當事務A執(zhí)行 update 時會對 id = 1 這行數(shù)據(jù)的排它鎖。
在事務A未提交的情況下,如果開啟事務B執(zhí)行 update ,會出現(xiàn)鎖等待然后超時:Lock wait timeout exceeded; try restarting transaction
間隙鎖(Gap Lock)
鎖定索引記錄之間的間隙,防止其他事務在范圍內插入新數(shù)據(jù)。
-- id 在 1 和 10 之間的間隙會被加排他鎖。 update product_sale_record WHERE id > 1 AND id < 10; -- id 在 1 和 10 之間的間隙會被加共享鎖。 select * from product_sale_record WHERE id > 1 AND id < 10 LOCK IN SHARE MODE;
臨鍵鎖(Next-Key Lock)
臨鍵鎖可以理解為是記錄鎖和間隙鎖的組合,鎖定索引記錄及其前面的間隙。
-- id > 1 的記錄及其前面的間隙會被加排他鎖 update product_sale_record WHERE id > 1; -- id > 1 的記錄及其前面的間隙會被加共享鎖 select * from product_sale_record where id > 1 LOCK IN SHARE MODE;
到此這篇關于MySQL中的行級鎖的文章就介紹到這了,更多相關mysql行級鎖內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
CenOS6.7下mysql 8.0.22 安裝配置方法圖文教程
這篇文章主要為大家詳細介紹了CenOS6.7下mysql 8.0.22 安裝配置方法圖文教程,文中安裝步驟介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-11-11MySQL中TINYINT、INT 和 BIGINT的具體使用
MySQL提供了多種整數(shù)類型來滿足不同的數(shù)據(jù)存儲需求,本文主要介紹了MySQL中TINYINT、INT 和 BIGINT的具體使用,具有一定的參考價值,感興趣的可以了解一下2024-07-07