亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL數(shù)據(jù)庫事務(wù)隔離級(jí)別介紹(Transaction Isolation Level)

 更新時(shí)間:2014年05月01日 23:46:06   作者:  
這篇文章主要介紹了MySQL數(shù)據(jù)庫事務(wù)隔離級(jí)別(Transaction Isolation Level) ,需要的朋友可以參考下

數(shù)據(jù)庫隔離級(jí)別有四種,應(yīng)用《高性能mysql》一書中的說明:

然后說說修改事務(wù)隔離級(jí)別的方法:

1.全局修改,修改mysql.ini配置文件,在最后加上

復(fù)制代碼 代碼如下:

 #可選參數(shù)有:READ-UNCOMMITTED, READ-COMMITTED, REPEATABLE-READ, SERIALIZABLE.
 [mysqld]
 transaction-isolation = REPEATABLE-READ

這里全局默認(rèn)是REPEATABLE-READ,其實(shí)MySQL本來默認(rèn)也是這個(gè)級(jí)別

2.對(duì)當(dāng)前session修改,在登錄mysql客戶端后,執(zhí)行命令:

要記住mysql有一個(gè)autocommit參數(shù),默認(rèn)是on,他的作用是每一條單獨(dú)的查詢都是一個(gè)事務(wù),并且自動(dòng)開始,自動(dòng)提交(執(zhí)行完以后就自動(dòng)結(jié)束了,如果你要適用select for update,而不手動(dòng)調(diào)用 start transaction,這個(gè)for update的行鎖機(jī)制等于沒用,因?yàn)樾墟i在自動(dòng)提交后就釋放了),所以事務(wù)隔離級(jí)別和鎖機(jī)制即使你不顯式調(diào)用start transaction,這種機(jī)制在單獨(dú)的一條查詢語句中也是適用的,分析鎖的運(yùn)作的時(shí)候一定要注意這一點(diǎn)

再來說說鎖機(jī)制:
共享鎖:由讀表操作加上的鎖,加鎖后其他用戶只能獲取該表或行的共享鎖,不能獲取排它鎖,也就是說只能讀不能寫

排它鎖:由寫表操作加上的鎖,加鎖后其他用戶不能獲取該表或行的任何鎖,典型是mysql事務(wù)中

復(fù)制代碼 代碼如下:

start transaction;
select * from user where userId = 1 for update;

執(zhí)行完這句以后

  1)當(dāng)其他事務(wù)想要獲取共享鎖,比如事務(wù)隔離級(jí)別為SERIALIZABLE的事務(wù),執(zhí)行

復(fù)制代碼 代碼如下:

  select * from user;

   將會(huì)被掛起,因?yàn)镾ERIALIZABLE的select語句需要獲取共享鎖

  2)當(dāng)其他事務(wù)執(zhí)行

復(fù)制代碼 代碼如下:

select * from user where userId = 1 for update;
update user set userAge = 100 where userId = 1;

也會(huì)被掛起,因?yàn)閒or update會(huì)獲取這一行數(shù)據(jù)的排它鎖,需要等到前一個(gè)事務(wù)釋放該排它鎖才可以繼續(xù)進(jìn)行

鎖的范圍:

行鎖: 對(duì)某行記錄加上鎖
表鎖: 對(duì)整個(gè)表加上鎖

這樣組合起來就有,行級(jí)共享鎖,表級(jí)共享鎖,行級(jí)排他鎖,表級(jí)排他鎖

下面來說說不同的事務(wù)隔離級(jí)別的實(shí)例效果,例子使用InnoDB,開啟兩個(gè)客戶端A,B,在A中修改事務(wù)隔離級(jí)別,在B中開啟事務(wù)并修改數(shù)據(jù),然后在A中的事務(wù)查看B的事務(wù)修改效果:

1.READ-UNCOMMITTED(讀取未提交內(nèi)容)級(jí)別

  1)A修改事務(wù)級(jí)別并開始事務(wù),對(duì)user表做一次查詢

   

  2)B更新一條記錄

   

  3)此時(shí)B事務(wù)還未提交,A在事務(wù)內(nèi)做一次查詢,發(fā)現(xiàn)查詢結(jié)果已經(jīng)改變

   

  4)B進(jìn)行事務(wù)回滾

   

  5)A再做一次查詢,查詢結(jié)果又變回去了

   

  6)A表對(duì)user表數(shù)據(jù)進(jìn)行修改

   

  7)B表重新開始事務(wù)后,對(duì)user表記錄進(jìn)行修改,修改被掛起,直至超時(shí),但是對(duì)另一條數(shù)據(jù)的修改成功,說明A的修改對(duì)user表的數(shù)據(jù)行加行共享鎖(因?yàn)榭梢允褂胹elect)

   

  可以看出READ-UNCOMMITTED隔離級(jí)別,當(dāng)兩個(gè)事務(wù)同時(shí)進(jìn)行時(shí),即使事務(wù)沒有提交,所做的修改也會(huì)對(duì)事務(wù)內(nèi)的查詢做出影響,這種級(jí)別顯然很不安全。但是在表對(duì)某行進(jìn)行修改時(shí),會(huì)對(duì)該行加上行共享鎖

2. READ-COMMITTED(讀取提交內(nèi)容)

  1)設(shè)置A的事務(wù)隔離級(jí)別,并進(jìn)入事務(wù)做一次查詢

   

  2)B開始事務(wù),并對(duì)記錄進(jìn)行修改

   

  3)A再對(duì)user表進(jìn)行查詢,發(fā)現(xiàn)記錄沒有受到影響

   

  4)B提交事務(wù)

   

  5)A再對(duì)user表查詢,發(fā)現(xiàn)記錄被修改

   

  6)A對(duì)user表進(jìn)行修改

   

  7)B重新開始事務(wù),并對(duì)user表同一條進(jìn)行修改,發(fā)現(xiàn)修改被掛起,直到超時(shí),但對(duì)另一條記錄修改,卻是成功,說明A的修改對(duì)user表加上了行共享鎖(因?yàn)榭梢詓elect)

   

   

  READ-COMMITTED事務(wù)隔離級(jí)別,只有在事務(wù)提交后,才會(huì)對(duì)另一個(gè)事務(wù)產(chǎn)生影響,并且在對(duì)表進(jìn)行修改時(shí),會(huì)對(duì)表數(shù)據(jù)行加上行共享鎖

3. REPEATABLE-READ(可重讀)

  1)A設(shè)置事務(wù)隔離級(jí)別,進(jìn)入事務(wù)后查詢一次

   

  2)B開始事務(wù),并對(duì)user表進(jìn)行修改

   

  3)A查看user表數(shù)據(jù),數(shù)據(jù)未發(fā)生改變

   

  4)B提交事務(wù)

   

  5)A再進(jìn)行一次查詢,結(jié)果還是沒有變化

   

  6)A提交事務(wù)后,再查看結(jié)果,結(jié)果已經(jīng)更新

   

  7)A重新開始事務(wù),并對(duì)user表進(jìn)行修改

   

   

  8)B表重新開始事務(wù),并對(duì)user表進(jìn)行修改,修改被掛起,直到超時(shí),對(duì)另一條記錄修改卻成功,說明A對(duì)表進(jìn)行修改時(shí)加了行共享鎖(可以select)

   

   

  REPEATABLE-READ事務(wù)隔離級(jí)別,當(dāng)兩個(gè)事務(wù)同時(shí)進(jìn)行時(shí),其中一個(gè)事務(wù)修改數(shù)據(jù)對(duì)另一個(gè)事務(wù)不會(huì)造成影響,即使修改的事務(wù)已經(jīng)提交也不會(huì)對(duì)另一個(gè)事務(wù)造成影響。

  在事務(wù)中對(duì)某條記錄修改,會(huì)對(duì)記錄加上行共享鎖,直到事務(wù)結(jié)束才會(huì)釋放。

4.SERIERLIZED(可串行化)

  1)修改A的事務(wù)隔離級(jí)別,并作一次查詢

   

  2)B對(duì)表進(jìn)行查詢,正常得出結(jié)果,可知對(duì)user表的查詢是可以進(jìn)行的

   

  3)B開始事務(wù),并對(duì)記錄做修改,因?yàn)锳事務(wù)未提交,所以B的修改處于等待狀態(tài),等待A事務(wù)結(jié)束,最后超時(shí),說明A在對(duì)user表做查詢操作后,對(duì)表加上了共享鎖

   

  SERIALIZABLE事務(wù)隔離級(jí)別最嚴(yán)厲,在進(jìn)行查詢時(shí)就會(huì)對(duì)表或行加上共享鎖,其他事務(wù)對(duì)該表將只能進(jìn)行讀操作,而不能進(jìn)行寫操作。

相關(guān)文章

  • 淺談選擇mysql存儲(chǔ)引擎的標(biāo)準(zhǔn)

    淺談選擇mysql存儲(chǔ)引擎的標(biāo)準(zhǔn)

    本文介紹了如何選擇mysql存儲(chǔ)引擎,從存儲(chǔ)引擎的介紹、幾個(gè)常用引擎的特點(diǎn)三個(gè)方面進(jìn)行講解,感興趣的小伙伴們可以參考一下
    2015-07-07
  • MySQL遷移到PostgreSQL操作指南

    MySQL遷移到PostgreSQL操作指南

    這篇文章主要介紹了MySQL遷移到PostgreSQL操作指南,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起來學(xué)習(xí)吧
    2023-10-10
  • MySql帶OR關(guān)鍵字的多條件查詢語句

    MySql帶OR關(guān)鍵字的多條件查詢語句

    MySQL帶OR關(guān)鍵字的多條件查詢,與AND關(guān)鍵字不同,OR關(guān)鍵字,只要記錄滿足任意一個(gè)條件,就會(huì)被查詢出來。即AND的優(yōu)先級(jí)高于OR
    2017-07-07
  • MySQL substr函數(shù)使用方法詳解

    MySQL substr函數(shù)使用方法詳解

    MySQL substr函數(shù)是指從一個(gè)內(nèi)容中,按照指定條件,「截取」一個(gè)字符串,這個(gè)內(nèi)容可以是數(shù)值或字符串,本文就來給大家講講MySQL substr函數(shù)的使用方法,需要的朋友可以參考下
    2023-07-07
  • mysql5.7安裝教程(windows)

    mysql5.7安裝教程(windows)

    這篇文章主要為大家詳細(xì)介紹了windows下mysql5.7安裝教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • 快速解決mysql導(dǎo)出scv文件亂碼、躥行的問題

    快速解決mysql導(dǎo)出scv文件亂碼、躥行的問題

    這篇文章主要介紹了快速解決mysql導(dǎo)出scv文件亂碼、躥行的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • mysql大小寫敏感導(dǎo)致程序無法啟動(dòng)的問題

    mysql大小寫敏感導(dǎo)致程序無法啟動(dòng)的問題

    這篇文章主要介紹了mysql大小寫敏感導(dǎo)致程序無法啟動(dòng)的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • Mysql 原生語句中save or update 的寫法匯總

    Mysql 原生語句中save or update 的寫法匯總

    這篇文章主要介紹了Mysql 原生語句中save or update 的寫法匯總,非常詳細(xì),需要的朋友可以參考下
    2015-03-03
  • 關(guān)于MySQL的體系結(jié)構(gòu)及存儲(chǔ)引擎圖解

    關(guān)于MySQL的體系結(jié)構(gòu)及存儲(chǔ)引擎圖解

    這篇文章主要介紹了關(guān)于MySQL的體系結(jié)構(gòu)及存儲(chǔ)引擎圖解,MySQL整體的邏輯結(jié)構(gòu)可以分為4層,客戶層、服務(wù)層、存儲(chǔ)引擎層、數(shù)據(jù)層,需要的朋友可以參考下
    2023-05-05
  • SQL行列轉(zhuǎn)換超詳細(xì)四種方法詳解

    SQL行列轉(zhuǎn)換超詳細(xì)四種方法詳解

    在數(shù)據(jù)分析的面試中SQL問題基本上是必問的,其中SQL行列轉(zhuǎn)換的問題出鏡率極其高,重要性也是不言而喻,下面這篇文章主要給大家介紹了關(guān)于SQL行列轉(zhuǎn)換超詳細(xì)四種方法的相關(guān)資料,需要的朋友可以參考下
    2022-12-12

最新評(píng)論