溫馨提示×

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

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

如何優(yōu)化mysql行鎖

發(fā)布時(shí)間:2021-05-25 16:07:47 來源:億速云 閱讀:204 作者:Leah 欄目:編程語言

如何優(yōu)化mysql行鎖?針對(duì)這個(gè)問題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡單易行的方法。

1、優(yōu)化方法

盡可能讓所有數(shù)據(jù)檢索都通過索引來完成,避免無索引行或索引失效導(dǎo)致行鎖升級(jí)為表鎖。

盡可能避免間隙鎖帶來的性能下降,減少或使用合理的檢索范圍。

盡可能減少事務(wù)的粒度,比如控制事務(wù)大小,而從減少鎖定資源量和時(shí)間長度,從而減少鎖的競(jìng)爭等,提供性能。

盡可能低級(jí)別事務(wù)隔離,隔離級(jí)別越高,并發(fā)的處理能力越低。

2、實(shí)例

CREATE TABLE `user` (
  `name` VARCHAR(32) DEFAULT NULL,
  `count` INT(11) DEFAULT NULL,
  `id` INT(11) NOT NULL AUTO_INCREMENT,
  PRIMARY KEY (`id`)
) ENGINE=INNODB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8
 
-- 這里,我們建一個(gè)user表,主鍵為id
 
 
 
-- A通過主鍵執(zhí)行插入操作,但事務(wù)未提交
update user set count=10 where id=1;
-- B在此時(shí)也執(zhí)行更新操作
update user set count=10 where id=2;
-- 由于是通過主鍵選中的,為行級(jí)鎖,A和B操作的不是同一行,B執(zhí)行的操作是可以執(zhí)行的
 
 
 
-- A通過name執(zhí)行插入操作,但事務(wù)未提交
update user set count=10 where name='xxx';
-- B在此時(shí)也執(zhí)行更新操作
update user set count=10 where id=2;

關(guān)于如何優(yōu)化mysql行鎖問題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。

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

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎ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