MySQL數(shù)據(jù)庫(kù)中行鎖是對(duì)數(shù)據(jù)庫(kù)表中某一行數(shù)據(jù)進(jìn)行操作時(shí),對(duì)該行數(shù)據(jù)進(jìn)行加鎖,同一時(shí)刻只有一個(gè)事務(wù)可以對(duì)該行數(shù)據(jù)進(jìn)行操作。
MySQL支持兩種行鎖機(jī)制:共享鎖(shared lock)和排他鎖(exclusive lock)。
共享鎖在讀取數(shù)據(jù)時(shí)使用,只允許其他事務(wù)也獲得共享鎖,但不允許其他事務(wù)獲得排它鎖。
排它鎖在修改數(shù)據(jù)時(shí)使用,不允許其他事務(wù)獲得任何類型的鎖。只有當(dāng)前持有排它鎖的事務(wù)才能對(duì)該行數(shù)據(jù)進(jìn)行修改操作。
-- 加共享鎖 SELECT * FROM table_name WHERE id = 1 LOCK IN SHARE MODE; -- 加排它鎖 SELECT * FROM table_name WHERE id = 1 FOR UPDATE;
在使用行鎖時(shí),需要注意以下幾點(diǎn):
1. 行鎖可能導(dǎo)致死鎖。當(dāng)多個(gè)事務(wù)同時(shí)請(qǐng)求相同的數(shù)據(jù)行進(jìn)行操作時(shí),容易造成死鎖。因此,在設(shè)計(jì)數(shù)據(jù)庫(kù)表時(shí),應(yīng)該盡可能減少鎖競(jìng)爭(zhēng)。
2. 鎖定粒度過(guò)細(xì)或過(guò)大可能導(dǎo)致性能降低。鎖定過(guò)細(xì)會(huì)導(dǎo)致系統(tǒng)頻繁加鎖解鎖,鎖定過(guò)大會(huì)導(dǎo)致鎖競(jìng)爭(zhēng)激烈。因此,在設(shè)計(jì)數(shù)據(jù)庫(kù)表時(shí),應(yīng)該合理劃分鎖粒度。
3. 行鎖具有自動(dòng)解鎖機(jī)制。當(dāng)事務(wù)提交或回滾時(shí),MySQL自動(dòng)解鎖所有已經(jīng)鎖定的數(shù)據(jù)行。