MySQL?原理與優(yōu)化之原數(shù)據(jù)鎖的應(yīng)用
MySQL 中原數(shù)據(jù)鎖是系統(tǒng)自動(dòng)控制添加的,對(duì)于用戶來說無需顯示調(diào)用,當(dāng)我們使用一張表的時(shí)候就會(huì)加上原數(shù)據(jù)鎖。
原數(shù)據(jù)鎖的作用是為了保護(hù)表原數(shù)據(jù)的一致性,如果在表上有活動(dòng)事務(wù)的時(shí)候,不可以對(duì)元數(shù)據(jù)進(jìn)行寫入操作。也就是為了避免DML 和DDL 之間的沖突,保證讀寫的正確性。
說白了就是,在對(duì)數(shù)據(jù)表進(jìn)行讀寫操作的時(shí)候,不能進(jìn)行修改表結(jié)構(gòu)的操作。
如上圖所示,在執(zhí)行select 操作的時(shí)候,MySQL 會(huì)自動(dòng)加上shared_read 鎖,在insert,update, delete 以及 select for update 操作的時(shí)候會(huì)加上shared_write 鎖,這兩類鎖是兼容的。
在執(zhí)行alter table 操作的時(shí)候,會(huì)加上 exclusive 鎖,這個(gè)鎖與shared_read 和 shared_write 鎖 是互斥的,換句話說在做查詢和更新表數(shù)據(jù)的時(shí)候,是不能夠修改表結(jié)構(gòu)的。
來看個(gè)例子:
首先開啟事務(wù),使用select 語句會(huì)針對(duì)表加上shared_read的共享鎖
begin; select * from course;
此時(shí)查看原數(shù)據(jù)鎖的信息:
select object_type,object_schema,object_name,lock_type,lock_duration from performance_schema.metadata_locks;
通過上圖我們可以發(fā)現(xiàn),course 表加上了shared_read鎖。
接著,開啟另外一個(gè)事務(wù),記住剛才的事務(wù)不要commit
begin; update course set name = 'Jason' where id =2;
如上圖所示,此時(shí)的update 語句可以執(zhí)行成功,并沒有被阻塞。說明select 和update 是不沖突的,他們的鎖是兼容的。
再次查看原數(shù)據(jù)鎖
select object_type,object_schema,object_name,lock_type,lock_duration from performance_schema.metadata_locks;
從上面的截圖可以看出,此時(shí)原數(shù)據(jù)鎖的表中記錄了兩條記錄分別是針對(duì)course 表的shared_read 和 shared_write 鎖,也剛好對(duì)應(yīng)我們執(zhí)行的select 和update 操作。
最后,我們?cè)賳?dòng)第三個(gè)客戶端,并且啟動(dòng) 第三個(gè)事務(wù),執(zhí)行alter語句,在course 表中加入一個(gè)字段hello 如下 。
begin; alter table course add column hello int;
由于之前的事務(wù)沒有提交所以修改表的操作會(huì)被阻塞,因?yàn)閟hared_read 以及 shared_write 這兩個(gè)鎖 與 exclusive之間是互斥的,所以會(huì)阻塞。
此時(shí),回到最開始的兩個(gè)客戶端,對(duì)兩個(gè)事務(wù)進(jìn)行commit 操作,再返回到第三個(gè)事務(wù)執(zhí)行的alter 語句出,發(fā)現(xiàn)語句順利執(zhí)行。
到此這篇關(guān)于MySQL 原理與優(yōu)化之原數(shù)據(jù)鎖的應(yīng)用的文章就介紹到這了,更多相關(guān)MySQL原數(shù)據(jù)鎖應(yīng)用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL rownumber SQL生成自增長(zhǎng)序號(hào)使用介紹
MySQL 幾乎模擬了 Oracle,SQL Server等商業(yè)數(shù)據(jù)庫的大部分功能,函數(shù)。但很可惜,到目前的版本(5.1.33)為止,仍沒有實(shí)現(xiàn)ROWNUM這個(gè)功能2011-10-10MySQL在grant時(shí)報(bào)錯(cuò)ERROR?1064?(42000)的原因及解決方法
網(wǎng)上查到的grant方式大多會(huì)報(bào)錯(cuò),主要原因是MySQL版本8.0后不能再使用原來的方式,這篇文章主要介紹了MySQL在grant時(shí)報(bào)錯(cuò)ERROR?1064?(42000),需要的朋友可以參考下2022-08-08Mysql實(shí)現(xiàn)定時(shí)清空一張表的舊數(shù)據(jù)并保留幾條數(shù)據(jù)(推薦)
這篇文章主要介紹了Mysql實(shí)現(xiàn)定時(shí)清空一張表的舊數(shù)據(jù)并保留幾條數(shù)據(jù),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12MySQL因大事務(wù)導(dǎo)致的Insert慢實(shí)例分析
這篇文章主要給大家介紹了關(guān)于MySQL因大事務(wù)導(dǎo)致Insert慢的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-10-10Navicat連接MySQL提示1045錯(cuò)誤解決(重置MySQL密碼)
連接MySQL數(shù)據(jù)庫時(shí)難免會(huì)遇到1045錯(cuò)誤,主要是因?yàn)橛脩糨斎氲挠脩裘蛎艽a錯(cuò)誤被拒絕訪問,如果不想重裝,需要找回密碼或者重置密碼,這篇文章主要給大家介紹了關(guān)于Navicat連接MySQL提示1045錯(cuò)誤解決的方法,主要是重置MySQL密碼,需要的朋友可以參考下2023-04-04Mysql 服務(wù) 1067 錯(cuò)誤 的解決方法:修改mysql可執(zhí)行文件路徑
這篇文章主要介紹了Mysql 服務(wù) 1067 錯(cuò)誤 的解決方法:修改mysql可執(zhí)行文件路徑的相關(guān)資料,需要的朋友可以參考下2017-05-05MySQL數(shù)據(jù)庫中把int轉(zhuǎn)化varchar引發(fā)的慢查詢
這篇文章主要介紹了MySQL數(shù)據(jù)庫中把int轉(zhuǎn)化varchar引發(fā)的慢查詢 的相關(guān)資料,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下2016-07-07關(guān)于k8s環(huán)境部署mysql主從的問題
這篇文章主要介紹了k8s環(huán)境部署mysql主從的問題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03