电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

瀏覽:3日期: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 數據庫
相關文章:
主站蜘蛛池模板: 高空重型升降平台_高空液压举升平台_高空作业平台_移动式升降机-河南华鹰机械设备有限公司 | 砍排机-锯骨机-冻肉切丁机-熟肉切片机-预制菜生产线一站式服务厂商 - 广州市祥九瑞盈机械设备有限公司 | 有福网(yofus.com)洗照片冲印,毕业聚会纪念册相册制作个性DIY平台 | 酒精检测棒,数显温湿度计,酒安酒精测试仪,酒精检测仪,呼气式酒精检测仪-郑州欧诺仪器有限公司 | DAIKIN电磁阀-意大利ATOS电磁阀-上海乾拓贸易有限公司 | 烟气换热器_GGH烟气换热器_空气预热器_高温气气换热器-青岛康景辉 | 回转窑-水泥|石灰|冶金-巩义市瑞光金属制品有限责任公司 | 鑫达滑石-辽宁鑫达滑石集团 | 智能垃圾箱|垃圾房|垃圾分类亭|垃圾分类箱专业生产厂家定做-宿迁市传宇环保设备有限公司 | 深圳法律咨询【24小时在线】深圳律师咨询免费 | 江西自考网-江西自学考试网 | 双能x射线骨密度检测仪_dxa骨密度仪_双能x线骨密度仪_品牌厂家【品源医疗】 | 扫地车厂家-山西洗地机-太原电动扫地车「大同朔州吕梁晋中忻州长治晋城洗地机」山西锦力环保科技有限公司 | 南京PVC快速门厂家南京快速卷帘门_南京pvc快速门_世界500强企业国内供应商_南京美高门业 | 安平县鑫川金属丝网制品有限公司,防风抑尘网,单峰防风抑尘,不锈钢防风抑尘网,铝板防风抑尘网,镀铝锌防风抑尘网 | 烟气在线监测系统_烟气在线监测仪_扬尘检测仪_空气质量监测站「山东风途物联网」 | 3A别墅漆/3A环保漆_广东美涂士建材股份有限公司【官网】 | 百度爱采购运营研究社社群-店铺托管-爱采购代运营-良言多米网络公司 | 并网柜,汇流箱,电控设备,中高低压开关柜,电气电力成套设备,PLC控制设备订制厂家,江苏昌伟业新能源科技有限公司 | 篮球地板厂家_舞台木地板品牌_体育运动地板厂家_凯洁地板 | 上海恒驭仪器有限公司-实验室平板硫化机-小型平板硫化机-全自动平板硫化机 | 浩方智通 - 防关联浏览器 - 跨境电商浏览器 - 云雀浏览器 | 大倾角皮带机-皮带输送机-螺旋输送机-矿用皮带输送机价格厂家-河南坤威机械 | 电竞馆加盟,沈阳网吧加盟费用选择嘉棋电竞_售后服务一体化 | 煤棒机_增碳剂颗粒机_活性炭颗粒机_木炭粉成型机-巩义市老城振华机械厂 | China plate rolling machine manufacturer,cone rolling machine-Saint Fighter | 橡胶接头|可曲挠橡胶接头|橡胶软接头安装使用教程-上海松夏官方网站 | 对夹式止回阀厂家,温州对夹式止回阀制造商--永嘉县润丰阀门有限公司 | 发电机组|柴油发电机组-批发,上柴,玉柴,潍柴,康明斯柴油发电机厂家直销 | 软文推广发布平台_新闻稿件自助发布_媒体邀约-澜媒宝 | ◆大型吹塑加工|吹塑加工|吹塑代加工|吹塑加工厂|吹塑设备|滚塑加工|滚塑代加工-莱力奇塑业有限公司 | 活性炭-果壳木质煤质柱状粉状蜂窝活性炭厂家价格多少钱 | 开平机_纵剪机厂家_开平机生产厂家|诚信互赢-泰安瑞烨精工机械制造有限公司 | 咖啡加盟,咖啡店加盟连锁品牌-卡小逗| 校园文化空间设计-数字化|中医文化空间设计-党建|法治廉政主题文化空间施工-山东锐尚文化传播公司 | 门禁卡_智能IC卡_滴胶卡制作_硅胶腕带-卡立方rfid定制厂家 | 钢衬四氟管道_钢衬四氟直管_聚四氟乙烯衬里管件_聚四氟乙烯衬里管道-沧州汇霖管道科技有限公司 | 湖南长沙商标注册专利申请,长沙公司注册代理记账首选美创! | 广东护栏厂家-广州护栏网厂家-广东省安麦斯交通设施有限公司 | 昆山PCB加工_SMT贴片_PCB抄板_线路板焊接加工-昆山腾宸电子科技有限公司 | 折弯机-刨槽机-数控折弯机-数控刨槽机-数控折弯机厂家-深圳豐科机械有限公司 |