這篇文章主要介紹了MySQL資料庫事務隔離層級詳解的相關資料,需要的朋友可以參考下
資料庫事務隔離等級
資料庫交易的隔離等級有4個,由低到高依序為
Read uncommitted:允許髒讀。
Read committed: 防止髒讀,最常用的隔離等級,並且是大多數資料庫的預設隔離等級。
Repeatable read:可以防止髒讀和無法重複讀取。
Serializable:可防止髒讀,不可重複讀取和幻讀,(交易串列化)會降低資料庫的效率。
這四個等級可以逐一解決髒讀 、不可重複讀 、幻讀 這幾類問題。
√: 可能出現×: 不會出現
交易層級 | 髒讀 | 無法重複讀取 | 幻讀 |
---|---|---|---|
Read uncommitted | ##√√ | √ | |
× | √ | √ | |
#× | × | √ | |
× | ##× | × |
髒讀:
髒讀就是指當一個交易正在存取數據,並且對數據進行了修改,而這種修改還沒有提交到資料庫中,這時,另一個事務也訪問這個數據,然後使用了這個數據。
無法重複讀取:是指在一個交易內,多次讀取相同資料。在這個事務還沒結束時,另外一個事務也存取該相同資料。那麼,在第一個事務中的兩次讀取資料之間,由於第二個事務的修改,那麼第一個事務兩次讀到的的資料可能是不一樣的。這樣就發生了在一個事務內兩次讀到的資料是不一樣的,因此稱為是不可重複讀。 (即不能讀到相同的資料內容)
幻讀:是指當事務不是獨立執行時發生的一種現象,例如第一個事務對一個表格中的資料進行了修改,這種修改涉及到表中的全部資料行。同時,第二個事務也修改這個表中的數據,這種修改是向表中插入一行新數據。那麼,以後就會發生操作第一個事務的使用者發現表中還有沒有修改的資料行,就好像發生了幻覺一樣。
example:
表:
CREATE TABLE `cc_wsyw126_user_test_isolation_copy` ( `id` int(11) NOT NULL AUTO_INCREMENT, `password` varchar(64) NOT NULL, `age` int(11) NOT NULL, PRIMARY KEY (`id`), KEY `ix_age` (`age`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8;
模擬資料:
INSERT INTO `cc_wsyw126_user_test_isolation_copy` (`password`, `age`) VALUES ('1', 1), ('2', 2), ('3', 3), ('4', 4);
第一個交易A:
start transaction insert into cc_wsyw126_user_test_isolation_copy (password, age) values ('5',5) commit
第二個事務B:
start transaction update cc_wsyw126_user_test_isolation_copy set age = 2 where password >='2' select * from cc_wsyw126_user_test_isolation_copy where password >= '2'; commit重現步驟:
只要A事務的insert語句,在B事務select之前和update之後即可。
MySQL InnoDB儲存引擎,實現的是基於多版本的並發控制協定-
MVCC (Multi-Version Concurrency Control) 加上間隙鎖定(next -key locking)策略在Repeatable Read (RR)隔離等級下不存在幻讀。如果測試幻讀,在MyISAM下實驗。 在聚集
索引(主鍵索引)中,如果有唯一性約束,InnoDB會將預設的next-key lock降級為record lock。
以上是詳細介紹MySQL資料庫事務隔離級別的詳細內容。更多資訊請關注PHP中文網其他相關文章!