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

您的位置:首頁技術文章
文章詳情頁

MySQL 行鎖和表鎖的含義及區別詳解

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

一、前言

對于行鎖和表鎖的含義區別,在面試中應該是高頻出現的,我們應該對MySQL中的鎖有一個系統的認識,更詳細的需要自行查閱資料,本篇為概括性的總結回答。

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

相對其他數據庫而言,MySQL的鎖機制比較簡單,其最顯著的特點是不同的存儲引擎支持不同的鎖機制。

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

表級鎖:開銷小,加鎖快;不會出現死鎖;鎖定粒度大,發生鎖沖突的概率最高,并發度最低。 行級鎖:開銷大,加鎖慢;會出現死鎖;鎖定粒度最小,發生鎖沖突的概率最低,并發度也最高。 頁面鎖:開銷和加鎖時間界于表鎖和行鎖之間;會出現死鎖;鎖定粒度界于表鎖和行鎖之間,并發度一般

如何加鎖?

MyISAM在執行查詢語句(SELECT)前,會自動給涉及的所有表加讀鎖,在執行更新操作(UPDATE、DELETE、INSERT等)前,會自動給涉及的表加寫鎖,這個過程并不需要用戶干預,因此用戶一般不需要直接用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;

二、表鎖

不會出現死鎖,發生鎖沖突幾率高,并發低。

MyISAM引擎

MyISAM在執行查詢語句(select)前,會自動給涉及的所有表加讀鎖,在執行增刪改操作前,會自動給涉及的表加寫鎖。

MySQL的表級鎖有兩種模式:

表共享讀鎖 表獨占寫鎖

讀鎖會阻塞寫,寫鎖會阻塞讀和寫

對MyISAM表的讀操作,不會阻塞其它進程對同一表的讀請求,但會阻塞對同一表的寫請求。只有當讀鎖釋放后,才會執行其它進程的寫操作。 對MyISAM表的寫操作,會阻塞其它進程對同一表的讀和寫操作,只有當寫鎖釋放后,才會執行其它進程的讀寫操作。

MyISAM不適合做寫為主表的引擎,因為寫鎖后,其它線程不能做任何操作,大量的更新會使查詢很難得到鎖,從而造成永遠阻塞

三、行鎖

會出現死鎖,發生鎖沖突幾率低,并發高。

在MySQL的InnoDB引擎支持行鎖,與Oracle不同,MySQL的行鎖是通過索引加載的,也就是說,行鎖是加在索引響應的行上的,要是對應的SQL語句沒有走索引,則會全表掃描,行鎖則無法實現,取而代之的是表鎖,此時其它事務無法對當前表進行更新或插入操作。

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-- 這里,我們建一個user表,主鍵為id -- A通過主鍵執行插入操作,但事務未提交update user set count=10 where id=1;-- B在此時也執行更新操作update user set count=10 where id=2;-- 由于是通過主鍵選中的,為行級鎖,A和B操作的不是同一行,B執行的操作是可以執行的 -- A通過name執行插入操作,但事務未提交update user set count=10 where name=’xxx’;-- B在此時也執行更新操作update user set count=10 where id=2;-- 由于是通過非主鍵或索引選中的,升級為為表級鎖,-- B則無法對該表進行更新或插入操作,只有當A提交事務后,B才會成功執行

for update

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

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

行鎖的實現需要注意:

行鎖必須有索引才能實現,否則會自動鎖全表,那么就不是行鎖了。 兩個事務不能鎖同一個索引。 insert,delete,update在事務中都會自動默認加上排它鎖。

行鎖場景:

A用戶消費,service層先查詢該用戶的賬戶余額,若余額足夠,則進行后續的扣款操作;這種情況查詢的時候應該對該記錄進行加鎖。

否則,B用戶在A用戶查詢后消費前先一步將A用戶賬號上的錢轉走,而此時A用戶已經進行了用戶余額是否足夠的判斷,則可能會出現余額已經不足但卻扣款成功的情況。

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

擴展:間隙鎖

當我們用范圍條件而不是相等條件檢索數據,并請求共享或排他鎖時,InnoDB會給符合條件的已有數據記錄的索引項加鎖;對于鍵值在條件范圍內并不存在的記錄,叫做間隙

InnoDB也會對這個'間隙'加鎖,這種鎖機制就是所謂的間隙鎖

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

如果用戶A在進行了上述操作后,事務還未提交,則B無法對2~6之間的記錄進行更新或插入記錄,會阻塞,當A將事務提交后,B的更新操作會執行。

建議:

盡可能讓所有數據檢索都通過索引來完成,避免無索引行鎖升級為表鎖 合理設計索引,盡量縮小鎖的范圍 盡可能減少索引條件,避免間隙鎖 盡量控制事務大小,減少鎖定資源量和時間長度

到此這篇關于MySQL 行鎖和表鎖的含義及區別詳解的文章就介紹到這了,更多相關MySQL 行鎖和表鎖內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: MySQL 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
午夜久久av | 亚洲香蕉视频| 亚洲人妖在线| 国产欧美高清视频在线| 国产精品一区二区av交换| 欧美韩日一区| 狠狠色狠狠色综合日日tαg| 视频精品一区二区| 亚洲免费观看高清完整版在线观| 久久国产精品色av免费看| 97精品国产福利一区二区三区| 美女毛片一区二区三区四区 | 欧美精品资源| 免费日韩视频| 国产激情欧美| 久久一区二区三区电影| 亚洲91网站| 国产一区二区三区不卡视频网站| 欧美精选一区二区三区| 日韩不卡免费视频| 日韩不卡视频在线观看| 丝瓜av网站精品一区二区| 国产高清精品二区| 五月天综合网站| 国产精品夜夜夜| 九一国产精品| 美日韩一区二区三区| 蜜臀久久99精品久久一区二区| 欧美日韩中出| 国产一区日韩欧美| 久久激情五月婷婷| 欧美亚洲精品在线| 国产欧美日韩| 国产精品婷婷| 久久久久久夜| 日韩高清在线观看一区二区| 亚洲啊v在线| 日韩欧美2区| 九九在线精品| 国产一区二区精品福利地址| 三级一区在线视频先锋| 国产精品伦理久久久久久| 亚洲九九精品| 亚洲成av人片一区二区密柚| 国产欧美一级| 精品1区2区3区4区| 日本久久精品| 日韩精品三区四区| 久久亚洲专区| 激情久久99| 日韩精品视频在线看| 免费欧美一区| 激情国产在线| 欧美欧美黄在线二区| 国产精品日本| 成人羞羞在线观看网站| 国产欧美日韩亚洲一区二区三区| 亚洲一区亚洲| 成人精品亚洲| 成人午夜网址| 国产探花一区在线观看| 丝袜美腿亚洲色图| 免费视频一区三区| 秋霞影院一区二区三区| 红杏一区二区三区| 美腿丝袜亚洲三区| 日韩精彩视频在线观看| 久久99伊人| 亚洲精品一二三区区别| 深夜视频一区二区| 国产一区二区三区久久久久久久久| 日本麻豆一区二区三区视频| 99热精品在线| 欧美1区2区3区| 成人精品天堂一区二区三区| 国产精品国产三级国产在线观看| 国产麻豆精品| 欧美日韩 国产精品| 中文字幕日韩高清在线| 欧美日韩视频| 欧美日韩激情在线一区二区三区| 国产精品99一区二区三区| 国产区精品区| 青青草国产成人99久久| 天堂va欧美ⅴa亚洲va一国产| 香蕉成人久久| 国产模特精品视频久久久久| 欧美天堂亚洲电影院在线观看| 精品一区在线| 亚洲免费黄色| 亚洲在线成人| 视频精品一区二区| 亚洲欧美日韩国产一区| 黄色亚洲在线| 久久福利毛片| 亚洲人www| 亚洲va久久久噜噜噜久久| 亚洲精品影院在线观看| 午夜久久av| 欧美日本不卡高清| 国产日韩亚洲| 麻豆精品国产91久久久久久| 久久精品理论片| 国精品产品一区| 中文字幕在线视频久| 日韩一区欧美| 国产一区日韩一区| 奶水喷射视频一区| 天堂av一区| 国产精品日韩精品中文字幕| 欧美91在线| 亚洲精品**中文毛片| 成人久久久久| 国产精品美女久久久| 一区二区三区网站| 欧美永久精品| 久久精品人人| 99久久99视频只有精品| 日韩午夜av| 日韩精品欧美精品| 久久99高清| 91精品蜜臀一区二区三区在线| 欧美+日本+国产+在线a∨观看| 视频一区视频二区在线观看| 欧美一区自拍| 国产精品毛片久久| 不卡一区综合视频| 蜜桃视频免费观看一区| 国产欧美在线| 亚洲风情在线资源| 男人的天堂久久精品| 国产亚洲欧美日韩在线观看一区二区| 国产精品草草| 日韩深夜视频| 国精品一区二区| 少妇精品久久久一区二区 | 免费日韩成人| 久久精品国产99久久| 蜜桃视频一区二区三区在线观看| 国产欧美日韩在线观看视频| 国产suv精品一区二区四区视频 | 免费精品视频在线| 18国产精品| av一区在线| 亚洲精品在线a| 日本久久精品| 伊人国产精品| 中文字幕在线官网| 中文无码日韩欧| 久久精品国产亚洲aⅴ| 欧美日韩高清| 国产精品免费大片| 国产一区亚洲| 97精品国产99久久久久久免费| 国产精品xx| 日韩精品视频一区二区三区| av日韩中文| 美国三级日本三级久久99| 麻豆国产一区| 亚洲综合不卡| 福利一区在线| 午夜久久av| 婷婷精品视频| 国产精品theporn| 一本一道久久a久久精品蜜桃| 国产美女亚洲精品7777| 亚洲婷婷免费| 国产欧美日韩免费观看| 香蕉久久99| 老司机免费视频一区二区三区| 夜久久久久久| 福利欧美精品在线| 日韩一区二区三区在线看| 日韩精品专区| 国产精品一区二区精品| 久久成人一区| 日本精品影院| 久久亚洲道色| 日韩激情一区二区| 亚洲精品成人| 麻豆国产在线| 欧美视频二区| 日韩制服丝袜av| 日韩一区欧美| 久久99久久人婷婷精品综合| 免费日韩av片| 激情视频一区二区三区| 麻豆精品新av中文字幕| 天堂久久一区| 99视频一区| 桃色一区二区| 国产精品2区| 日韩视频一二区| 尤物网精品视频| 日韩久久精品| 麻豆视频久久| 国产精品2区| 欧美日韩一区二区国产| 日韩中文字幕亚洲一区二区va在线| 久久天堂av|