npm mysql 事務 mysql事務隔離級別

2021-10-19 19:54:16 字數 1714 閱讀 4551

準備命令:

//檢視隔離級別

select @@global.tx_isolation, @@tx_isolation;

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

set session tx_isolation='read-uncommitted';

set session tx_isolation='read-committed';

set session tx_isolation='repeatable-read';

read uncommitted

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

會話一:未提交

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

read committed

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

會話一:第一步,開啟事務,查詢資料

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

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

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

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

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

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

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

repeatable read(可重讀)

解決"可重複讀"

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

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

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

如下:

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

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

serializable(可序列化)

mysql 事務 數量 Mysql 事務

什麼是事務 不可分割的操作,比如乙個事務要修改 a 表和刪除 b 表的資料兩個操作,這兩個操作都成功,這個事務才 commit,不然 rollback 每條 sql 語句都是乙個事務 只對 dml 生效 caid 一致性 consistency 讓資料保持一定程度的合理性,比如使用者加入購物車,購物...

mysql事務機制 Mysql事務機制

mysql事務是指將資料庫從一種一致性狀態轉到另一種一致性狀態 mysql事務具有acid特性 原子性 atomicity 事務中的所有操作,要麼全部執行,要麼都不執行 一致性 consistency 事務開始和結束後,資料庫的完整性不會被破壞 隔離性 isolation 事務之間互不影響。事務的隔...

mysql事務死鎖 MySQL事務 死鎖

一 概念 多個事務在同一資源上互相占用形成迴路。這就是死鎖 基本命令 檢視是否自動提交事務 show variables like autocommit 設定事務是否自動提交 set autocommit 0 set autocommit 1 二 例子 create table user id bi...