mysql事務隔離級別

2022-09-06 21:57:30 字數 1694 閱讀 9325

sql標準定義了4種隔離級別,

低階別的隔離級別一般支援更高的併發處理,並擁有更低的系統開銷

但是低階別的隔離級別,會讓各級別之間干擾會更大一些

事務隔離級別有四種

1.read uncommitted(讀取未提交內容)

(1)首先,修改隔離級別

set tx_isolation='read-uncommitted';
select @@tx_isolation;
(2)事務a:
create table abc (name char(20),nianling int(3));
insert into abc values ('a',20);

insert into abc values ('b',18);

啟動乙個事務
begin;

select * from abc;
+------+----------+
| name | nianling |
+------+----------+
| a    |       20    |
| b    |       18    |
+------+----------+
(3)事務b  我們在開啟乙個xshell 登入到資料庫後,在開啟乙個事務,執行完事務後,不提交

mysql> begin;

mysql> select * from abc;

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

| name | nianling |

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

| a    |     20   |

| b    |     18   |

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

mysql> update abc set nianling=25 where name='a';

我們更改abc的內容,但是不提交

(4)在事務a上檢視事務b 的更改。我們是能看到事務b的內容的。

mysql> select * from abc;

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

| name | nianling |

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

| a    |       25 |

| b    |       18 |

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

即使在事務b上回滾,在a上也可以b上回滾後的內容。

即使b提交了事務,a事務也可以看到提交後的內容。

read committed(讀取提交內容)

repeatable read(可重讀)

serializable(可序列化)

這是mysql的預設事務隔離級別,它確保同一事務的多個例項在併發讀取資料時,會看到同樣的資料行。不過理論上,這會導致另乙個棘手的問題:幻讀 (phantom read)。簡單的說,幻讀指當使用者讀取某一範圍的資料行時,另乙個事務又在該範圍內插入了新行,當使用者再讀取該範圍的資料行時,會發現有新的「幻影」 行。innodb和falcon儲存引擎通過多版本併發控制(mvcc,multiversion concurrency control)機制解決了該問題。

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