Mysql 事務隔離級別 InnoDB實現隔離機制

2021-08-06 06:31:00 字數 1447 閱讀 4427

在read uncommitted級別中,事務所做的寫操作,即使沒有提交,對其他事務也是可見的,a事務可以讀取b事務未提交的資料,這就叫做未提交讀/髒讀。 這個級別會導致很多問題,但從效能上來說,並不比其他級別好太多

大部分資料庫系統的預設隔離級別就是 read committed,它解決了髒讀的問題,當乙個事務開始時,只能「看見」已提交的事務所做的修改。但這也會引入乙個不可重複讀的問題:事務a在執行過程中有兩次對變數a的讀取,而在這兩次讀取之間,事務b對a做了修改,就會導致事務a的兩次讀取出的值不同,這就叫「不可重複讀」。

可重複讀是mysql的預設事務隔離級別

repeatable read 解決了不可重複讀的問題,它保證了在同乙個事務中多次讀取同一條記錄的結果是一致的,但理論上,它無法解決另外乙個幻讀的問題,即:在事務a中兩次讀取某個範圍的記錄,在兩次讀取之間,另乙個事務b在該範圍插入了新的記錄,當事務a再次讀取時,會產生幻行。innodb儲存引擎通過多版本併發控制(mvcc) 解決了幻讀的問題。

serializable是最高的隔離級別,它強制事務序列執行(或者它本身就是個單執行緒的模型,例如redis)。但在普通的資料庫中,序列化會導致大量的加鎖和鎖競爭問題,從而耗費大量的資源,除非是在非常需要確保資料一致性而可以接受沒有併發的情況下,才考慮採用該級別。

mysql 預設採用自動提交的模式,也就是說,如果不是顯式地開啟乙個事務,則每個查詢都會被當作乙個事務來執行提交操作,在當前連線中,可以通過設定autocommit變數來啟用或禁用自動提交模式。

當autocommit=0時,所有的查詢都在乙個事務中,直到顯式地執行了commit 或 rollback,該事務才結束。

事務開始時刻的版本號會作為本次事務的版本號,用來和每行記錄的版本號進行比較,具體比較方式如下:

只查詢建立版本小於等於當前版本,並且刪除版本不存在或大於當前版本的記錄

這樣能保證本次事務select的行,只讀取到在本次事務執行前就存在,或是被本次事務新增的資料。

為新插入的每一行儲存當前事務版本號,作為該行的建立版本號

為刪除的每一行儲存當前事務版本號,作為該行的刪除版本號

插入一行新記錄,儲存當前事務版本號作為該行建立版本號,並同時儲存當前版本號到原來的行作為刪除版本號

有這兩個版本號的存在,使得大多數讀操作不用加鎖,這樣設計使得讀操作很簡單,效能良好,並且也保證了只會讀取到符合標準的行。但不足之處是需要額外的儲存空間,並且需要更多的行檢查工作和維護工作。

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