mysql事務隔離級別

2022-07-19 06:57:15 字數 1677 閱讀 1945

準備命令:

//檢視隔離級別

select @@global.tx_isolatio

n, @@tx_isolation; 

//修改當前會話隔離級別

set session tx_isolation='read-uncommitted';

set session tx_isolation='read-committed';

set session tx_isolation='repeatable-read';

read uncommitted

在兩個會話執行如下操作,

會話一:未提交 

會話二:可以看到未提交的結果

修改會話隔離級別如上(略)

會話一:第一步,

開啟事務,查詢資料

會話二:第一步,開啟事務,更新資料,但不提交

會話一:第二步,在同一事務下,再次執行查詢,看不到會話二未提交的資料

當會話二提交後,會話一方可看到修改後的結果。

但會出現"不可重複讀",如下:

會話一:開啟事務,先執行第一次查詢

會話二:開啟事務,執行update操作並提交

會話一:保持之前開啟的事務,執行第二次查詢,和第一次的結果不一樣,查詢到了中間會話二提交的內容(行級鎖,不鎖間隙)

repeatable read(可重讀)

解決"可重複讀"

會話一:開啟事務,先執行第一次查詢

會話二:開啟事務,執行update操作並提交

會話一:保持之前開啟的事務,執行第二次查詢,和第一次的結果一樣,查詢不到中間會話二提交的內容(行級鎖且是鎖間隙)

如下:

幻讀:指當使用者讀取某一範圍的資料行時,另乙個事務又在該範圍內插入了新行,當使用者再讀取該範圍的資料行時,會發現有新的「幻影」 行。

innodb和falcon儲存引擎通過多版本併發控制(mvcc,multiversion concurrency control)機制解決了該問題。

serializable(可序列化)

mysql隔離級別 MySQL 事務隔離級別

mysql innodb所提供的事務滿足acid的要求,事務是通過事務日誌中的redo log和undo log來實現原子性 undo log 一致性 undo log 永續性 redo log 事務通過鎖機制實現隔離性。1 事務隔離級別與實現read uncommitted 讀未提交 read c...

MySQL事務隔離級別

sql標準定義了4類隔離級別,包括了一些具體規則,用來限定事務內外的哪些改變是可見的,哪些是不可見的。低階別的隔離級一般支援更高的 併發處理,並擁有更低的系統開銷。read uncommitted 讀取未提交內容 在該隔離級別,所有事務都可以看到其他未提交事務的執行結果。本隔離級別很少用於實際應用,...

Mysql 事務隔離級別

mysql 5.5預設儲存引擎 表型別 使用的是innodb,它是支援acid特性的 acid,指資料庫的原子性 atomicity 一致性 consistency 隔離性 isolation 永續性 durability 乙個支援事務 transaction 的資料庫系統,必需要具有這四種特性,否...