MySQL對于各種鎖的概念理解
樂觀鎖
樂觀鎖大多是基于數(shù)據(jù)版本記錄機制實現(xiàn),一般是給數(shù)據(jù)庫表增加一個"version"字段。讀取數(shù)據(jù)時,將此版本號一同讀出,之后更新時,對此版本號加一。此時將提交數(shù)據(jù)的版本數(shù)據(jù)與數(shù)據(jù)庫表對應記錄的當前版本信息進行比對,如果提交的數(shù)據(jù)版本號大于數(shù)據(jù)庫表當前版本號,則予以更新,否則認為是過期數(shù)據(jù)。
比如下單操作:
查詢出商品信息。
select (quantity, version)
from t_goods
where id = #{id}
根據(jù)商品信息生成訂單。
將商品數(shù)量減1。
update t_goods
set quantity = quantity - 1
where id = #{id} and version = #{version}
悲觀鎖
悲觀鎖依靠數(shù)據(jù)庫提供的鎖機制實現(xiàn)。MySQL中的共享鎖和排它鎖都是悲觀鎖。數(shù)據(jù)庫的增刪改操作默認都會加排他鎖,而查詢不會加任何鎖。
共享鎖(讀鎖)
共享鎖指的就是對于多個不同的事務,對于一個資源共享同一個鎖。對某一資源加共享鎖,自身可可讀該資源,其他人也可以讀該資源(也可以再加共享鎖,即共享鎖共享多個內存),但無法修改。要想修改就必須等所有共享鎖都釋放完之后。語法:select * from table lock in share mode;。
比如:
窗口1,在一個未結束的事務中給一條數(shù)據(jù)加上共享鎖。
BEGIN; SELECT * FROM t_red_packet WHERE id = 1 LOCK IN SHARE MODE;
窗口2,給同一條數(shù)據(jù)加上共享鎖,加鎖成功。
SELECT * FROM t_red_packet WHERE id = 1 LOCK IN SHARE MODE;
窗口1和窗口2,更新該行數(shù)據(jù),提示[Err] 1205 - Lock wait timeout exceeded; try restarting transaction。需要等到所有共享鎖釋放,才可以進行update操作。
UPDATE t_red_packet SET user_id = 2
排它鎖(寫鎖)
排它鎖指的就是對于多個不同的事務,對同一個資源只能有一把鎖。對某一資源加排它鎖,自身可以進行增刪改查,其他人無法進行加鎖操作,更無法進行增刪改操作。語法:select * from table for update。
窗口1,在一個未結束的事務中給一條數(shù)據(jù)加上排它鎖。
BEGIN; SELECT * FROM t_red_packet WHERE id = 1 FOR UPDATE;
窗口1,更新該行數(shù)據(jù),成功。
UPDATE t_red_packet SET user_id = 2
窗口2,查詢該行數(shù)據(jù),可以查詢到。
SELECT * FROM t_red_packet WHERE id = 1
窗口2給該條數(shù)據(jù)加鎖,提示[Err] 1205 - Lock wait timeout exceeded; try restarting transaction。
SELECT * FROM t_red_packet WHERE id = 1 FOR UPDATE;
綜上,共享鎖就是大家一起來讀,一起來共享鎖,但誰都不要對鎖著的數(shù)據(jù)進行修改,排它鎖就是我自己就是想來修改,你們可以讀,但你們都不能到鎖,也不能對數(shù)據(jù)進行修改。
行鎖
行鎖就是給一行數(shù)據(jù)進行加鎖。
表鎖
表鎖就是對一張表進行加鎖。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關內容請查看下面相關鏈接
相關文章
淺談MySQL 統(tǒng)計行數(shù)的 count
這篇文章主要介紹了MySQL 統(tǒng)計行數(shù)的 count的相關資料,文中講解非常細致,代碼幫助大家更好的理解和學習,感興趣的朋友可以了解下2020-07-07
SQL Server 2005 安裝遇到的錯誤提示和解決方法
在安裝SQL Server 2005時有時會出現(xiàn)意想不到的問題,如IIS,性能計數(shù)器,OWC11,無法配置外圍應用的問題,下面筆者分享一下在安裝SQL Server 2005時常見問題解決方法2014-01-01
MySQL核心參數(shù)優(yōu)化文件my.ini實現(xiàn)
本文主要介紹了MySQL核心參數(shù)優(yōu)化文件my.ini實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-01-01
MySQL中LAG()函數(shù)和LEAD()函數(shù)的使用
這篇文章主要介紹了MySQL中LAG()函數(shù)和LEAD()函數(shù)的使用,包括窗口函數(shù)的基本用法,LAG()和LEAD()函數(shù)介紹,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-08-08
詳解用SELECT命令在MySQL執(zhí)行查詢操作的教程
這篇文章主要介紹了詳解用SELECT命令在MySQL執(zhí)行查詢操作的教程,本文中還給出了基于PHP腳本的操作演示,需要的朋友可以參考下2015-05-05
MySQL之select in 子查詢優(yōu)化的實現(xiàn)
這篇文章主要介紹了MySQL之select in 子查詢優(yōu)化的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-09-09

