婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MySQL 行鎖和表鎖的含義及區別詳解

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

熱門標簽:申請400電話電話價格 臨沂做地圖標注 廣東400企業電話申請流程 許昌外呼增值業務線路 咸陽防封電銷卡 新鄉智能外呼系統好處 石家莊400電話辦理公司 宜賓全自動外呼系統廠家 地圖標注客戶付款

一、前言

對于行鎖和表鎖的含義區別,在面試中應該是高頻出現的,我們應該對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也會對這個"間隙"加鎖,這種鎖機制就是所謂的間隙鎖

-- 用戶A
update user set count=8 where id>2 and id6

-- 用戶B
update user set count=10 where id=5;

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

建議:

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

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

您可能感興趣的文章:
  • Mysql事務中Update是否會鎖表?
  • MySQL數據庫鎖機制原理解析
  • mysql查看死鎖與去除死鎖示例詳解
  • MySQL死鎖檢查處理的正常方法
  • mysql查詢表是否被鎖的方法
  • 通過實例判斷mysql update是否會鎖表
  • MySQL中的悲觀鎖與樂觀鎖
  • mysql 悲觀鎖與樂觀鎖的理解及應用分析
  • MySQL 8.0.19支持輸入3次錯誤密碼鎖定賬戶功能(例子)
  • MySQL 鎖的相關知識總結

標簽:貴州 合肥 鎮江 鷹潭 北京 阜新 臺灣 日照

巨人網絡通訊聲明:本文標題《MySQL 行鎖和表鎖的含義及區別詳解》,本文關鍵詞  MySQL,行鎖,和,表鎖,的,含義,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL 行鎖和表鎖的含義及區別詳解》相關的同類信息!
  • 本頁收集關于MySQL 行鎖和表鎖的含義及區別詳解的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    一区二区在线看| 欧美一区二区网站| 国产又黄又大久久| 亚洲女人小视频在线观看| av在线播放不卡| 国产成人免费在线观看| av动漫一区二区| 亚洲精品老司机| 在线免费不卡视频| 大胆欧美人体老妇| 天使萌一区二区三区免费观看| 国产亚洲制服色| 91免费在线看| 国内外精品视频| 日本欧美一区二区三区乱码| 一区二区三区免费观看| 在线综合+亚洲+欧美中文字幕| 狠狠色丁香婷综合久久| 成人免费高清在线| 欧美福利视频一区| 国产清纯白嫩初高生在线观看91 | 日韩精品一区国产麻豆| 精品剧情在线观看| 1024成人网| 蜜桃传媒麻豆第一区在线观看| 成人午夜激情片| 日韩精品影音先锋| 视频一区国产视频| 日本中文一区二区三区| 欧美日韩中文精品| 26uuu色噜噜精品一区| 国产一区二区看久久| 一区免费观看视频| 91色porny| 久久久久久久久久久99999| 性做久久久久久免费观看| 国产91综合网| 久久久久久久精| 日韩中文字幕一区二区三区| 99久久精品免费观看| 亚洲国产精品成人综合 | 7878成人国产在线观看| 午夜av一区二区| 自拍偷拍国产精品| 夜夜操天天操亚洲| va亚洲va日韩不卡在线观看| 欧美极品xxx| 国产毛片一区二区| 精品国产伦理网| 麻豆精品一二三| 日韩一区二区麻豆国产| 亚洲成人三级小说| 欧美一区二区三区影视| 奇米四色…亚洲| 日韩一区二区三区精品视频| 久久se精品一区精品二区| 欧美日韩在线电影| 亚洲成人av福利| 精品久久久久久综合日本欧美| 国产米奇在线777精品观看| 国产精品亲子乱子伦xxxx裸| 欧美精品色一区二区三区| 99精品视频一区| 亚洲国产精品久久人人爱| 亚洲欧美aⅴ...| 美女爽到高潮91| 欧美一二三在线| eeuss国产一区二区三区| 另类综合日韩欧美亚洲| 亚洲综合无码一区二区| 18成人在线观看| 国产亚洲精品超碰| 久久网这里都是精品| 欧美一区二区三区在线观看| 国产一区二三区| 麻豆精品在线看| 国产日韩影视精品| 7777精品伊人久久久大香线蕉的 | 日韩精品一区二区三区中文不卡| 成人毛片在线观看| 国产丶欧美丶日本不卡视频| 蜜臀av亚洲一区中文字幕| 亚洲国产综合色| 亚洲国产一区二区a毛片| 亚洲乱码精品一二三四区日韩在线| 制服丝袜激情欧洲亚洲| 欧美精品在线视频| 51久久夜色精品国产麻豆| 777精品伊人久久久久大香线蕉| 99精品久久久久久| 成人精品鲁一区一区二区| 国产a精品视频| 99亚偷拍自图区亚洲| 色综合天天综合狠狠| 成人性色生活片免费看爆迷你毛片| 日本网站在线观看一区二区三区| 亚洲一二三区在线观看| 亚洲国产va精品久久久不卡综合| 午夜精品久久久久久| 激情图区综合网| 欧美探花视频资源| 欧美日韩成人综合天天影院| 2017欧美狠狠色| 中文字幕中文字幕一区| 亚洲午夜精品网| 国产suv一区二区三区88区| 在线一区二区三区四区| 欧美大尺度电影在线| 亚洲乱码国产乱码精品精98午夜| 亚洲成人综合视频| 成人免费视频播放| 日韩美女视频在线| 亚洲风情在线资源站| 99精品一区二区| 欧美日韩精品一区二区三区| 国产精品久久福利| 国产一区不卡视频| 91麻豆精品国产自产在线观看一区 | 欧美日韩国产片| 国产精品久久久久久久久免费丝袜| 一区二区三区欧美久久| 国产69精品久久99不卡| 欧美精品久久一区| 青青草国产成人av片免费| 色综合天天综合狠狠| 日韩午夜激情电影| 毛片一区二区三区| 久久新电视剧免费观看| 韩国精品主播一区二区在线观看| 欧美日韩日本视频| 麻豆中文一区二区| 久久久久久综合| 成人精品视频.| 无码av免费一区二区三区试看| 欧美日本在线观看| 蜜臂av日日欢夜夜爽一区| 久久精品亚洲一区二区三区浴池| 中文字幕av在线一区二区三区| 亚洲资源中文字幕| 国产精品一级在线| 久久日韩粉嫩一区二区三区| 成人免费毛片app| 亚洲欧美一区二区三区极速播放| 日韩一级大片在线| 色噜噜狠狠一区二区三区果冻| 久草热8精品视频在线观看| 亚洲自拍偷拍av| 夜夜嗨av一区二区三区中文字幕| 欧美一区二区三区白人| 91蜜桃视频在线| 亚洲午夜一区二区| 亚洲天堂久久久久久久| 中文av字幕一区| 69堂精品视频| 欧美日韩在线电影| 在线精品亚洲一区二区不卡| 粉嫩av一区二区三区| 韩国三级中文字幕hd久久精品| 日韩成人一级大片| 日韩国产在线观看一区| 亚洲电影视频在线| 国产精品毛片无遮挡高清| 久久久久久9999| 欧美va在线播放| 欧美日韩国产乱码电影| 欧美三级中文字幕| 97久久精品人人做人人爽| a级精品国产片在线观看| 免费黄网站欧美| 另类中文字幕网| 国内精品免费在线观看| 午夜精品福利一区二区蜜股av | 欧美嫩在线观看| 日本道色综合久久| 欧美丰满少妇xxxxx高潮对白 | 奇米一区二区三区av| 全国精品久久少妇| 蜜臀av一级做a爰片久久| 成人高清伦理免费影院在线观看| 国产成人精品影视| 欧美精品乱码久久久久久按摩| 久久久九九九九| 乱中年女人伦av一区二区| 欧美日韩精品欧美日韩精品一综合| 欧美va日韩va| 亚洲成人av电影在线| 91官网在线观看| 成人免费视频在线观看| 国产精品免费丝袜| 亚洲午夜一区二区| 日韩精品五月天| 波波电影院一区二区三区| 日韩欧美高清一区| 亚洲日本乱码在线观看| 日韩电影在线免费看| 91亚洲精华国产精华精华液| 日韩欧美一卡二卡| 亚洲午夜精品17c| 不卡的电视剧免费网站有什么| 美女性感视频久久|