MySQL事務隔離級別

2021-10-24 04:49:42 字數 1787 閱讀 6904

innodb儲存引擎:innodb是事務型資料庫的首選引擎,支援事務安全表(acid)支援行鎖定和外來鍵,mysql5.5以後預設使用innodb儲存引擎

myisam儲存引擎:myisam基於isam儲存引擎,並對其進行擴充套件。它是在web、資料倉儲和其他應用環境下最常使用的儲存引擎之一。myisam擁有較高的插入、查詢速度,但不支援事務不支援外來鍵

memory儲存引擎:memory儲存引擎將表中的資料儲存到記憶體中,為查詢和引用其他表資料提供快速訪問,不支援事務不支援外來鍵

顯而易見,這些儲存引擎都是有不同的使用場景的,如果表對事物的要求高,應該使用innodb引擎,如果表對事物的要求不高,同時是以查詢和新增為主,我們考慮使用myisam儲存引擎或者memory儲存引擎。

讀未提交(read uncommitted):這是事務的最低隔離級別,即乙個事務還沒有提交,其他的讀取操作就可以獲取到事務的修改資料

原始資料:

將資料庫隔離級別改為讀未提交,再修改account值,但是事務不提交

再次查詢資料,查詢到的資料已經是修改後的資料,造成了髒讀

讀已提交(read committed)

設定隔離級別為讀已提交,再修改account但不提交事務

資料查詢到的是原始資料,解決髒讀問題

事務提交後,再次查詢,結果與上一步不一致,產生了不可重複讀的問題

可重複讀(repeatable read)(資料庫預設使用)

設定為可重複讀,修改account但是不提交事務

查詢資料,為原始數值,不存在髒讀問題

同一事物中,在事物提交前查詢和事務提交後查詢結果一致,不存在不可重複都問題

測試幻讀,插入資料

同一事務中,第一次查詢是一條資料,第二次查詢是兩條資料(第二次查詢為當前讀,加了排它鎖),出現幻讀現象,若第二次也如第一次查詢一樣,則為快照讀,結果為一條資料,不存在幻讀現象

4. 序列化(serializable):可以避免一切髒讀,不可重複讀,幻讀

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