溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

MySQL中鎖的概念是什么

發(fā)布時(shí)間:2021-06-16 16:49:00 來源:億速云 閱讀:153 作者:Leah 欄目:MySQL數(shù)據(jù)庫

今天就跟大家聊聊有關(guān)MySQL中鎖的概念是什么,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

樂觀鎖

樂觀鎖大多是基于數(shù)據(jù)版本記錄機(jī)制實(shí)現(xiàn),一般是給數(shù)據(jù)庫表增加一個(gè)"version"字段。讀取數(shù)據(jù)時(shí),將此版本號(hào)一同讀出,之后更新時(shí),對(duì)此版本號(hào)加一。此時(shí)將提交數(shù)據(jù)的版本數(shù)據(jù)與數(shù)據(jù)庫表對(duì)應(yīng)記錄的當(dāng)前版本信息進(jìn)行比對(duì),如果提交的數(shù)據(jù)版本號(hào)大于數(shù)據(jù)庫表當(dāng)前版本號(hào),則予以更新,否則認(rèn)為是過期數(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ù)庫提供的鎖機(jī)制實(shí)現(xiàn)。MySQL中的共享鎖和排它鎖都是悲觀鎖。數(shù)據(jù)庫的增刪改操作默認(rèn)都會(huì)加排他鎖,而查詢不會(huì)加任何鎖。

共享鎖(讀鎖)

共享鎖指的就是對(duì)于多個(gè)不同的事務(wù),對(duì)于一個(gè)資源共享同一個(gè)鎖。對(duì)某一資源加共享鎖,自身可可讀該資源,其他人也可以讀該資源(也可以再加共享鎖,即共享鎖共享多個(gè)內(nèi)存),但無法修改。要想修改就必須等所有共享鎖都釋放完之后。語法:select * from table lock in share mode;。

比如:

窗口1,在一個(gè)未結(jié)束的事務(wù)中給一條數(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。需要等到所有共享鎖釋放,才可以進(jìn)行update操作。

UPDATE t_red_packet
SET user_id = 2

排它鎖(寫鎖)

排它鎖指的就是對(duì)于多個(gè)不同的事務(wù),對(duì)同一個(gè)資源只能有一把鎖。對(duì)某一資源加排它鎖,自身可以進(jìn)行增刪改查,其他人無法進(jìn)行加鎖操作,更無法進(jìn)行增刪改操作。語法:select * from table for update。

窗口1,在一個(gè)未結(jié)束的事務(wù)中給一條數(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,查詢?cè)撔袛?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;

綜上,共享鎖就是大家一起來讀,一起來共享鎖,但誰都不要對(duì)鎖著的數(shù)據(jù)進(jìn)行修改,排它鎖就是我自己就是想來修改,你們可以讀,但你們都不能到鎖,也不能對(duì)數(shù)據(jù)進(jìn)行修改。

行鎖

行鎖就是給一行數(shù)據(jù)進(jìn)行加鎖。

表鎖

表鎖就是對(duì)一張表進(jìn)行加鎖。

看完上述內(nèi)容,你們對(duì)MySQL中鎖的概念是什么有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI