mysql 事務隔離級別

2021-09-12 04:24:17 字數 1565 閱讀 5470

使用者可以用[color=red]set transaction[/color]語句改變單個會話或者所有新進連線的隔離級別。它的語法如下:

set [session | global] transaction isolation level

[color=red]注意:預設的行為(不帶session和global)是為下乙個(未開始)事務設定隔離級別。[/color]如果你使用global關鍵字,語句在全域性對從那點開始建立的所有新連線(除了不存在的連線)設定預設事務級別。你需要super許可權來做這個。使用session 關鍵字為將來在當前連線上執行的事務設定預設事務級別。 任何客戶端都能自由改變會話隔離級別(甚至在事務的中間),或者為下乙個事務設定隔離級別。

你可以用下列語句查詢全域性和會話事務隔離級別:

select @@global.tx_isolation;

select @@session.tx_isolation;

select @@tx_isolation;

mysql> set @@tx_isolation='read-committed';

query ok, 0 rows affected (0.00 sec)

mysql> select @@session.tx_isolation;

+------------------------+

| @@session.tx_isolation |

+------------------------+

| repeatable-read |

+------------------------+

1 row in set (0.00 sec)

mysql> select @@tx_isolation;

+-----------------+

| @@tx_isolation |

+-----------------+

| repeatable-read |

+-----------------+

1 row in set (0.00 sec)

session事物的隔離級別並沒有改變。

mysql> set @@session.tx_isolation='read-committed';

query ok, 0 rows affected (0.00 sec)

mysql> select @@session.tx_isolation;

+------------------------+

| @@session.tx_isolation |

+------------------------+

| read-committed |

+------------------------+

1 row in set (0.00 sec)

已經改變了。

**:[url]

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 的資料庫系統,必需要具有這四種特性,否...