久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

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

一文帶你了解MySQL中的鎖機制

瀏覽:128日期:2023-02-18 16:43:52
目錄
  • 一.概述
    • 分類
  • 二.MyISAM表鎖
    • 如何加表鎖
    • 寫鎖演示
  • 三.InnoDB行鎖
    • 行鎖特點

一.概述

鎖是計算機協調多個進程或線程并發訪問某一資源的機制(避免爭搶)。

在數據庫中,除傳統的計算資源(如CPU、RAM、I/O等)的爭用以外,數據也是一種供許多用戶共享的資如何保證數據并發訪問的一致性、有效性是所有數據庫必須解決的一個問題,鎖沖突也是影響數據庫并發訪問性能的一個重要因素。從這個角度來說,鎖對數據庫而言顯得尤其重要,也更加復雜。

分類

1、從對數據操作的粒度分

  • 表鎖:操作時,會鎖定整個表。
  • 行鎖:操作時,會鎖定當前操作行。

2、從對數據操作的類型分

  • 讀鎖(共享鎖):針對同一份數據,多個讀操作可以同時進行而不會互相影響。
  • 寫鎖(排它鎖):當前操作沒有完成之前,它會阻斷其他寫鎖和讀鎖。

相對其他數據庫而言,MySQL的鎖機制比較簡單,其最顯著的特點是不同的存儲引擎支持不同的鎖機制。下表中羅列出了各存儲引擎對鎖的支持情況:

存儲引擎表級鎖行級鎖MylSAM支持不支持lnnoDB支持支持MEMORY支持不支持BDB支持不支持

MySQL鎖的特性可大致歸納如下:

鎖類型特點表級鎖偏向MyISAM存儲引擎,開銷小,加鎖快;不會出現死鎖;鎖定粒度大,發生鎖沖突的概率最高,并發度最低。行級鎖偏向InnoDB存儲引擎,開銷大,加鎖慢;會出現死鎖;鎖定粒度最小,發生鎖沖突的概率最低,并發度也最高。

從上述特點可見,很難籠統地說哪種鎖更好,只能就具體應用的特點來說哪種鎖更合適! 僅從鎖的角度來說:表級鎖更適合于以查詢為主,只有少量按索引條件更新數據的應用,如web應用;

而行級鎖則更適合于有大量按索引條件并發更新少量不同數據,同時又有并查詢的應用,如一些在線事務處理(OLTP)系統。

二.MyISAM表鎖

MylSAM存儲引擎只支持表鎖

如何加表鎖

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

讀鎖演示

create database test_lock;use test_lock; drop table tb_book ; create table tb_book(	id int(11) auto_increment,	name varchar(50) default null,	publish_time date default null,	status char(1) default null,	primary key (id))engine=myisam default charset=utf8; insert into tb_book values(null,"sql","2088-08-01","1");insert into tb_book values(null,"sql",20880908,"0");  create table tb_user(	id int(11) auto_increment,	name varchar(50) default null,	primary key (id)	)engine =myisam default charset=utf8; insert into tb_user values(null,"張三");insert into tb_user values(null,"李四"); -- 加讀鎖lock table tb_book read; select * from tb_book  ;-- 能正常輸出select * from tb_book tb ;-- 不能正常輸出,不能有別名update tb_book set status=1;-- 不能正常輸出 讀鎖:可讀不可改 select * from tb_user ;-- 不能正常輸出,當鎖住一個表時也不能看其他表-- 解鎖unlock tables;

加了讀鎖后只能看自己的表,不能修改,也不能看其他的表

寫鎖演示

create table tb_book(	id int(11) auto_increment,	name varchar(50) default null,	publish_time date default null,	status char(1) default null,	primary key (id))engine=myisam default charset=utf8; insert into tb_book values(null,"sql","2088-08-01","1");insert into tb_book values(null,"sql",20880908,"0");  create table tb_user(	id int(11) auto_increment,	name varchar(50) default null,	primary key (id)	)engine =myisam default charset=utf8; insert into tb_user values(null,"張三");insert into tb_user values(null,"李四"); -- 加寫鎖lock table tb_book write; select * from tb_book  ;-- 能正常輸出select * from tb_book tb ;-- 不能正常輸出,不能有別名update tb_book set status=1;-- 可以修改 寫鎖:可讀可修改,但在沒有解鎖之前不能被其他人查看,會被掛起 select * from tb_user ;-- 不能正常輸出,當鎖住一個表時也不能看其他表-- 解鎖unlock tables;

三.InnoDB行鎖

行鎖特點

行鎖特點︰偏向InnoDB存儲引擎,開銷大,加鎖慢;會出現死鎖;鎖定粒度最小,發生鎖沖突的概率最低,并發度也最高。

InnoDB與 MylSAM的最大不同有兩點:一是支持事務;二是采用了行級鎖。

行鎖模式

lnnoDB實現了以下兩種類型的行鎖。

1、共享鎖(S)∶又稱為讀鎖,簡稱s鎖,共享鎖就是多個事務對于同一數據可以共享一把鎖,都能訪問到數據,但是只能讀不能修改。

2、排他鎖(x):又稱為寫鎖,簡稱x鎖,排他鎖就是不能與其他鎖并存,如一個事務獲取了一個數據行的排他鎖,其他事務就不能再獲取該行的其他鎖,包括共享鎖和排他鎖,但是獲取排他鎖的事務是可以對數據就行讀取和修改。

對于UPDATE、DELETE和INSERT語句,InnoDB會自動給涉及數據集加排他鎖(x);

對于普通SELECT語句,InnoDB不會加任何鎖;

可以通過以下語句顯示給記錄集加共享鎖或排他鎖。

-- 行鎖 drop table is exists test_innodb_lock;create table test_innodb_lock(	id int(11),	name varchar(16),	sex varchar(1))engine=innodb; insert into test_innodb_lock values(1,"100","1"),									(2,"200","0"),									(3,"200","1"),									(4,"300","0"),									(5,"400","0"),									(6,"500","1"),									(7,"600","1"),									(1,"700","1"); create index index_id on test_innodb_lock(id);create index index_name on test_innodb_lock(name);

可以修改是因為上面的行鎖只對id=1的那兩行加了排他鎖

到此這篇關于一文帶你了解MySQL中的鎖機制的文章就介紹到這了,更多相關MySQL鎖機制內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

標簽: MySQL
主站蜘蛛池模板: 成人aaa| 99精品久久久 | 免费看国产一级片 | 亚洲国产精品成人综合色在线婷婷 | 亚洲精品久久久久国产 | 精品国产青草久久久久福利 | 久久久久国产 | 亚洲视频免费 | 国产目拍亚洲精品99久久精品 | 精品久久久久久久久久久久久久 | 中文字幕在线视频一区 | 国产91精选 | 久久99深爱久久99精品 | 亚洲h| 成人精品福利视频 | 91在线精品秘密一区二区 | 亚洲精品在线视频观看 | 国产欧美日本 | 国产91久久久久 | 亚洲成人精品 | 成人区一区二区三区 | 伊人91 | 午夜精品久久久久久99热软件 | 91麻豆精品国产91久久久更新资源速度超快 | 成人在线看片 | 欧美在线观看一区 | 日韩草比| 97成人在线 | 欧美一级黄色影院 | 精品不卡 | 波多野结衣一区在线观看 | 日本超碰在线 | 一区二区三区高清不卡 | www久久久| 国产一区二区三区免费观看 | 久久成人高清 | 国产区福利| 成人欧美一区二区三区色青冈 | 亚洲深深色噜噜狠狠网站 | 国产区在线| 日韩福利片 |