日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

MySQL 行鎖和表鎖的含義及區(qū)別詳解

瀏覽:59日期:2023-10-12 18:28:02

一、前言

對(duì)于行鎖和表鎖的含義區(qū)別,在面試中應(yīng)該是高頻出現(xiàn)的,我們應(yīng)該對(duì)MySQL中的鎖有一個(gè)系統(tǒng)的認(rèn)識(shí),更詳細(xì)的需要自行查閱資料,本篇為概括性的總結(jié)回答。

MySQL常用引擎有MyISAM和InnoDB,而InnoDB是mysql默認(rèn)的引擎。MyISAM不支持行鎖,而InnoDB支持行鎖和表鎖。

相對(duì)其他數(shù)據(jù)庫(kù)而言,MySQL的鎖機(jī)制比較簡(jiǎn)單,其最顯著的特點(diǎn)是不同的存儲(chǔ)引擎支持不同的鎖機(jī)制。

MySQL大致可歸納為以下3種鎖:

表級(jí)鎖:開銷小,加鎖快;不會(huì)出現(xiàn)死鎖;鎖定粒度大,發(fā)生鎖沖突的概率最高,并發(fā)度最低。 行級(jí)鎖:開銷大,加鎖慢;會(huì)出現(xiàn)死鎖;鎖定粒度最小,發(fā)生鎖沖突的概率最低,并發(fā)度也最高。 頁(yè)面鎖:開銷和加鎖時(shí)間界于表鎖和行鎖之間;會(huì)出現(xiàn)死鎖;鎖定粒度界于表鎖和行鎖之間,并發(fā)度一般

如何加鎖?

MyISAM在執(zhí)行查詢語(yǔ)句(SELECT)前,會(huì)自動(dòng)給涉及的所有表加讀鎖,在執(zhí)行更新操作(UPDATE、DELETE、INSERT等)前,會(huì)自動(dòng)給涉及的表加寫鎖,這個(gè)過(guò)程并不需要用戶干預(yù),因此用戶一般不需要直接用LOCK TABLE命令給MyISAM表顯式加鎖。

顯式加鎖:

上共享鎖(讀鎖)的寫法:lock in share mode,例如:

select math from zje where math>60 lock in share mode;

上排它鎖(寫鎖)的寫法:for update,例如:

select math from zje where math >60 for update;

二、表鎖

不會(huì)出現(xiàn)死鎖,發(fā)生鎖沖突幾率高,并發(fā)低。

MyISAM引擎

MyISAM在執(zhí)行查詢語(yǔ)句(select)前,會(huì)自動(dòng)給涉及的所有表加讀鎖,在執(zhí)行增刪改操作前,會(huì)自動(dòng)給涉及的表加寫鎖。

MySQL的表級(jí)鎖有兩種模式:

表共享讀鎖 表獨(dú)占寫鎖

讀鎖會(huì)阻塞寫,寫鎖會(huì)阻塞讀和寫

對(duì)MyISAM表的讀操作,不會(huì)阻塞其它進(jìn)程對(duì)同一表的讀請(qǐng)求,但會(huì)阻塞對(duì)同一表的寫請(qǐng)求。只有當(dāng)讀鎖釋放后,才會(huì)執(zhí)行其它進(jìn)程的寫操作。 對(duì)MyISAM表的寫操作,會(huì)阻塞其它進(jìn)程對(duì)同一表的讀和寫操作,只有當(dāng)寫鎖釋放后,才會(huì)執(zhí)行其它進(jìn)程的讀寫操作。

MyISAM不適合做寫為主表的引擎,因?yàn)閷戞i后,其它線程不能做任何操作,大量的更新會(huì)使查詢很難得到鎖,從而造成永遠(yuǎn)阻塞

三、行鎖

會(huì)出現(xiàn)死鎖,發(fā)生鎖沖突幾率低,并發(fā)高。

在MySQL的InnoDB引擎支持行鎖,與Oracle不同,MySQL的行鎖是通過(guò)索引加載的,也就是說(shuō),行鎖是加在索引響應(yīng)的行上的,要是對(duì)應(yīng)的SQL語(yǔ)句沒(méi)有走索引,則會(huì)全表掃描,行鎖則無(wú)法實(shí)現(xiàn),取而代之的是表鎖,此時(shí)其它事務(wù)無(wú)法對(duì)當(dāng)前表進(jìn)行更新或插入操作。

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通過(guò)主鍵執(zhí)行插入操作,但事務(wù)未提交update user set count=10 where id=1;-- B在此時(shí)也執(zhí)行更新操作update user set count=10 where id=2;-- 由于是通過(guò)主鍵選中的,為行級(jí)鎖,A和B操作的不是同一行,B執(zhí)行的操作是可以執(zhí)行的 -- A通過(guò)name執(zhí)行插入操作,但事務(wù)未提交update user set count=10 where name=’xxx’;-- B在此時(shí)也執(zhí)行更新操作update user set count=10 where id=2;-- 由于是通過(guò)非主鍵或索引選中的,升級(jí)為為表級(jí)鎖,-- B則無(wú)法對(duì)該表進(jìn)行更新或插入操作,只有當(dāng)A提交事務(wù)后,B才會(huì)成功執(zhí)行

for update

如果在一條select語(yǔ)句后加上for update,則查詢到的數(shù)據(jù)會(huì)被加上一條排它鎖,其它事務(wù)可以讀取,但不能進(jìn)行更新和插入操作

-- A用戶對(duì)id=1的記錄進(jìn)行加鎖select * from user where id=1 for update;-- B用戶無(wú)法對(duì)該記錄進(jìn)行操作update user set count=10 where id=1;-- A用戶commit以后則B用戶可以對(duì)該記錄進(jìn)行操作

行鎖的實(shí)現(xiàn)需要注意:

行鎖必須有索引才能實(shí)現(xiàn),否則會(huì)自動(dòng)鎖全表,那么就不是行鎖了。 兩個(gè)事務(wù)不能鎖同一個(gè)索引。 insert,delete,update在事務(wù)中都會(huì)自動(dòng)默認(rèn)加上排它鎖。

行鎖場(chǎng)景:

A用戶消費(fèi),service層先查詢?cè)撚脩舻馁~戶余額,若余額足夠,則進(jìn)行后續(xù)的扣款操作;這種情況查詢的時(shí)候應(yīng)該對(duì)該記錄進(jìn)行加鎖。

否則,B用戶在A用戶查詢后消費(fèi)前先一步將A用戶賬號(hào)上的錢轉(zhuǎn)走,而此時(shí)A用戶已經(jīng)進(jìn)行了用戶余額是否足夠的判斷,則可能會(huì)出現(xiàn)余額已經(jīng)不足但卻扣款成功的情況。

為了避免此情況,需要在A用戶操作該記錄的時(shí)候進(jìn)行for update加鎖

擴(kuò)展:間隙鎖

當(dāng)我們用范圍條件而不是相等條件檢索數(shù)據(jù),并請(qǐng)求共享或排他鎖時(shí),InnoDB會(huì)給符合條件的已有數(shù)據(jù)記錄的索引項(xiàng)加鎖;對(duì)于鍵值在條件范圍內(nèi)并不存在的記錄,叫做間隙

InnoDB也會(huì)對(duì)這個(gè)'間隙'加鎖,這種鎖機(jī)制就是所謂的間隙鎖

-- 用戶Aupdate user set count=8 where id>2 and id<6-- 用戶Bupdate user set count=10 where id=5;

如果用戶A在進(jìn)行了上述操作后,事務(wù)還未提交,則B無(wú)法對(duì)2~6之間的記錄進(jìn)行更新或插入記錄,會(huì)阻塞,當(dāng)A將事務(wù)提交后,B的更新操作會(huì)執(zhí)行。

建議:

盡可能讓所有數(shù)據(jù)檢索都通過(guò)索引來(lái)完成,避免無(wú)索引行鎖升級(jí)為表鎖 合理設(shè)計(jì)索引,盡量縮小鎖的范圍 盡可能減少索引條件,避免間隙鎖 盡量控制事務(wù)大小,減少鎖定資源量和時(shí)間長(zhǎng)度

到此這篇關(guān)于MySQL 行鎖和表鎖的含義及區(qū)別詳解的文章就介紹到這了,更多相關(guān)MySQL 行鎖和表鎖內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: MySQL 數(shù)據(jù)庫(kù)
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
天堂va在线高清一区| 欧美日韩在线观看首页| 亚洲乱码久久| 国产免费av国片精品草莓男男| 国产精品最新| 日韩和的一区二在线| 视频一区在线播放| 美女av一区| 激情五月综合网| 日韩在线黄色| 久久男人天堂| 蜜臀a∨国产成人精品| 国产精品麻豆成人av电影艾秋| 成人亚洲一区| 免费欧美在线视频| 国产精品一区高清| 久久中文视频| 日本视频中文字幕一区二区三区| 国产一区2区| 国产精品三上| 国产欧美69| 米奇777超碰欧美日韩亚洲| 日本一区福利在线| 啪啪国产精品| 国产三级一区| 欧美片第1页| 天堂精品久久久久| 999久久久免费精品国产| 91精品一区| 免费观看不卡av| 欧美精品自拍| 精品少妇av| 亚洲五月综合| 日韩成人亚洲| 国产伦精品一区二区三区视频 | 国产精品17p| 亚洲一区二区三区久久久| 成人国产精选| 免费看日韩精品| 黄在线观看免费网站ktv| 日韩国产在线不卡视频| 在线日韩av| 国产激情久久| 久久最新视频| 国产一区二区三区黄网站 | 久久久夜夜夜| 青草综合视频| 在线综合视频| 老牛影视精品| 国产欧美日韩综合一区在线播放| 激情综合网五月| 国产美女撒尿一区二区| 在线一区免费观看| 亚洲精品一级二级| 国产精品毛片久久久| 久久高清国产| 91欧美在线| 欧美日韩一区二区三区四区在线观看 | 你懂的国产精品永久在线| 日韩欧美国产精品综合嫩v| 亚洲人妖在线| 99成人在线视频| 青青草国产成人99久久| 亚洲国产专区| 久久xxx视频| 国产精品嫩草99av在线| 日本久久精品| 日本不卡一二三区黄网| 99久久亚洲精品蜜臀| 久久av导航| 日本不卡视频在线观看| 久久久久久久久成人| 国产91精品对白在线播放| 欧美午夜三级| 美女网站一区| 成人午夜亚洲| 91p九色成人| 欧美丝袜一区| 久久精品国产免费| 日韩激情精品| 日韩精品一卡二卡三卡四卡无卡| 在线人成日本视频| 欧美日韩亚洲国产精品| 午夜在线播放视频欧美| 麻豆理论在线观看| 国产精品草草| 日韩在线成人| 免费人成在线不卡| 欧美+日本+国产+在线a∨观看| 免费在线观看一区| 日韩激情啪啪| 中文字幕一区二区三区四区久久| av中文字幕在线观看第一页 | 日产精品一区二区| 国产亚洲精品美女久久久久久久久久| 伊人影院久久| 在线日韩电影| 欧美不卡高清一区二区三区| 欧美激情 亚洲a∨综合| 日本精品一区二区三区在线观看视频| 国产精品日本| 激情久久久久久| 久久婷婷激情| 水蜜桃精品av一区二区| 国产日韩一区二区三区在线 | 国产精品久久久久77777丨| 亚洲精品少妇| 首页亚洲欧美制服丝腿| 韩日一区二区三区| 久久久久国产| 国产一区二区三区天码| 美日韩一区二区三区| 日韩av中文字幕一区二区三区| 性色一区二区| 亚洲欧美日韩视频二区| 亚洲精品2区| 婷婷亚洲五月| 亚洲播播91| 日韩一区三区| 欧美aa在线观看| 日韩欧美少妇| 国产精品av一区二区| 欧美精品一区二区久久| 狠狠干成人综合网| 久久精品免费一区二区三区| 国产精品原创| 久久久久91| 国产精品成久久久久| 国产一区二区三区四区五区| 国产精品精品| 欧美日韩视频网站| 久热综合在线亚洲精品| 国产综合视频| 日韩欧美精品一区二区综合视频| 国产福利一区二区精品秒拍 | 偷拍亚洲精品| 你懂的国产精品永久在线| 欧产日产国产精品视频| 亚洲欧美日韩精品一区二区 | 精品国产一区二区三区2021| 久久精品国产在热久久| 久久精品毛片| 亚洲黄色网址| 欧美影院三区| 热久久国产精品| 7777精品| 成人三级高清视频在线看| 尤物tv在线精品| 综合五月婷婷| 国产精品一区二区美女视频免费看| 久久av资源| 欧产日产国产精品视频| 亚洲欧美日韩国产| 欧美片第1页综合| 久久亚洲国产精品尤物| 五月天av在线| 亚洲精品一区二区在线看| 亚洲丝袜美腿一区| 欧美a一区二区| 尤物tv在线精品| 亚洲精品大全| 精品亚洲精品| 性一交一乱一区二区洋洋av| 国产剧情在线观看一区| 国产在线观看www| 免费人成精品欧美精品| 免费在线观看一区| 精品欧美激情在线观看| 免费在线视频一区| 国产剧情一区二区在线观看| 日韩欧美精品综合| 蜜桃免费网站一区二区三区| 久久99影视| 宅男在线一区| 国产欧美一区二区三区国产幕精品 | a国产在线视频| 亚洲人成网77777色在线播放| 神马久久午夜| 国产私拍福利精品视频二区| 亚洲一区网站| 日韩免费小视频| 欧美日韩一区二区三区不卡视频 | 日产精品一区| 国产精品久久久久久模特| 国产亚洲欧洲| 久久九九国产| 鲁大师精品99久久久| 久久亚洲不卡| 91精品一区二区三区综合| 精品国产中文字幕第一页| 亚洲91网站| 亚洲激情av| 蜜桃av.网站在线观看| 国产精品视频一区二区三区| 美女日韩在线中文字幕| 成人久久一区| 精品三区视频| 欧美在线91| 亚洲精品一区二区在线播放∴| 五月天综合网站|