【MySQL】資料庫事務深入分析
一、前言
只有InnoDB引擎支援事務,下邊的內容均以InnoDB引擎為預設條件
二、常見的併發問題
1、髒讀
一個事務讀取了另一個事務未提交的資料
2、不可重複讀
一個事務對同一資料的讀取結果前後不一致。兩次讀取中間被其他事務修改了
3、幻讀
幻讀是指事務讀取某個範圍的資料時,因為其他事務的操作導致前後兩次讀取的結果不一致。幻讀和不可重複讀的區別在於,不可重複讀是針對確定的某一行資料而言,而幻讀是針對不確定的多行資料。因而幻讀通常出現在帶有查詢條件的範圍查詢中
三、事務隔離級別
1、讀未提交(READ UNCOMMITTED)
可能產生髒讀、不可重複讀、幻讀
2、讀已提交(READ COMMITTED)
避免了髒讀,可能產生不可重複讀、幻讀
3、可重複讀(REPEATABLE READ)(mysql預設隔離級別)
避免了髒讀,不可重複讀。通過區間鎖技術避免了幻讀
4、序列化(SERIALIZABLE)
序列化可以避免所有可能出現的併發異常,但是會極大的降低系統的併發處理能力
四、資料庫日誌有哪些?
1、undo日誌
undo日誌用於存放資料修改被修改前的值
UNDO LOG中分為兩種型別,一種是 INSERT_UNDO(INSERT操作),記錄插入的唯一鍵值;
一種是 UPDATE_UNDO(包含UPDATE及DELETE操作),記錄修改的唯一鍵值以及old column記錄。
2、redo日誌
mysql會將一個事務中的所有sq先l記錄到redo log中,然後再將記錄從redo log同步到資料檔案中
它可以帶來這些好處:
- 當buffer pool中的dirty page 還沒有重新整理到磁碟的時候,發生crash,啟動服務後,可通過redo log 找到需要重新重新整理到磁碟檔案的記錄;
- buffer pool中的資料直接flush到disk file,是一個隨機IO,效率較差,而把buffer pool中的資料記錄到redo log,是一個順序IO,可以提高事務提交的速度;
3、binlog日誌
用於資料庫主從複製的記錄,是二進位制格式。在事務提交之後進行一個磁碟寫入。
這裡注意下redo log 跟binary log 的區別,redo log 是儲存引擎層產生的,而binary log是資料庫層產生的。假設一個大事務,對tba做10萬行的記錄插入,在這個過程中,一直不斷的往redo log順序記錄,而binary log不會記錄,直到這個事務提交,才會一次寫入到binary log檔案中
五、資料庫事務控制
1、預設情況下,開啟事務自動提交功能。每執行一個sql,都會對應一個事務的提交
2、 spring會將底層連線的自動提交特性設定為false。使用手動提交
六、事務的ACID特性
1、原子性(Atomicity)
事務中的所有操作作為一個整體像原子一樣不可分割,要麼全部成功,要麼全部失敗。
2、一致性(Consistency)
事務的執行結果必須使資料庫從一個一致性狀態到另一個一致性狀態。一致性狀態是指:1.系統的狀態滿足資料的完整性約束(主碼,參照完整性,check約束等) 2.系統的狀態反應資料庫本應描述的現實世界的真實狀態,比如轉賬前後兩個賬戶的金額總和應該保持不變。
3、隔離性(Isolation)
併發執行的事務不會相互影響,其對資料庫的影響和它們序列執行時一樣。比如多個使用者同時往一個賬戶轉賬,最後賬戶的結果應該和他們按先後次序轉賬的結果一樣。
4、永續性(Durability)
事務一旦提交,其對資料庫的更新就是持久的。任何事務或系統故障都不會導致資料丟失。
5、redo log和undo log實現了原子性、一致性、永續性
6、鎖機制實現了隔離性
6.1、快照讀
讀取的是快照版本,也就是歷史版本。普通的SELECT就是快照讀
6.2、當前讀
讀取的是最新版本。UPDATE、DELETE、INSERT、SELECT … LOCK IN SHARE MODE、SELECT … FOR UPDATE是當前讀。
6.3、鎖定讀
在一個事務中,標準的SELECT語句是不會加鎖,但是有兩種情況例外。SELECT … LOCK IN SHARE MODE 和 SELECT … FOR UPDATE。
SELECT ... LOCK IN SHARE MODE
給記錄假設共享鎖,這樣一來的話,其它事務只能讀不能修改,直到當前事務提交
SELECT ... FOR UPDATE
給索引記錄加鎖,這種情況下跟UPDATE的加鎖情況是一樣的
6.4、一致性非鎖定讀
consistent read(一致性讀),InnoDB用多版本來提供查詢資料庫在某個時間點的快照。如果隔離級別是REPEATABLE READ,那麼在同一個事務中的所有一致性讀都讀的是事務中第一個這樣的讀讀到的快照;如果是READ COMMITTED,那麼一個事務中的每一個一致性讀都會讀到它自己重新整理的快照版本。Consistent read(一致性讀)是READ COMMITTED和REPEATABLE READ隔離級別下普通SELECT語句預設的模式。一致性讀不會給它所訪問的表加任何形式的鎖,因此其它事務可以同時併發的修改它們。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69946007/viewspace-2657172/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 資料庫事務與 MySQL 事務總結資料庫MySql
- MySQL資料庫本地事務原理MySql資料庫
- MySQL資料庫6:Go與MySQL事務MySql資料庫Go
- MySQL(一):MySQL資料庫事務與鎖MySql資料庫
- 資料庫對比系列之三(PG事務與MySQL事務)資料庫MySql
- Mysql資料庫之多表查詢、事務、DCLMySql資料庫
- MySQL資料庫詳解(三)MySQL的事務隔離剖析MySql資料庫
- MySQL資料庫引擎、事務隔離級別、鎖MySql資料庫
- MySQL資料庫事務隔離性的實現MySql資料庫
- MySQL資料庫學習筆記02(事務控制,資料查詢)MySql資料庫筆記
- C# 從程式碼入門 Mysql 資料庫事務C#MySql資料庫
- 資料庫篇:mysql事務原理之MVCC檢視+鎖資料庫MySqlMVC
- 說說資料庫事務資料庫
- 淺談資料庫事務資料庫
- 資料庫事務概論資料庫
- 資料庫事務的特徵資料庫特徵
- MySQL 資料庫-索引注意事項MySql資料庫索引
- 資料庫事務以及事務的四個特性資料庫
- MySQL資料庫分散式事務XA的實現原理分析MySql資料庫分散式
- MySQL InnoDB資料庫如何保證事務特性示例詳解MySql資料庫
- 【Mysql】資料庫事務,髒讀、幻讀、不可重複讀MySql資料庫
- 重新學習MySQL資料庫6:淺談MySQL的中事務與鎖MySql資料庫
- 資料庫主要物件及事務資料庫物件
- 資料庫事務入門指南資料庫
- Laravel 開啟資料庫事務Laravel資料庫
- Springboot資料庫事務處理——Spring宣告式事務Spring Boot資料庫
- 資料庫事務與事務的隔離級別資料庫
- 分散式事務之資料庫事務與JDBC事務實現(一)分散式資料庫JDBC
- 30000字學完MySql資料庫(安裝、SQL、索引、事務等)MySql資料庫索引
- [專業術語]資料庫事務資料庫
- MCMySQL 資料庫 索引和事務ktkMySql資料庫索引
- MySQL 資料庫設計和注意事項MySql資料庫
- 從 Oracle 轉型 MySQL 分散式事務資料庫的實戰旅途OracleMySql分散式資料庫
- 用【庫存】看懂雲開發資料庫事務資料庫
- MySQL資料庫的事務處理用法與例項程式碼詳解MySql資料庫
- MySQL資料庫事務各隔離級別加鎖情況--read uncommittMySql資料庫MIT
- MySQL資料庫事務各隔離級別加鎖情況--Repeatable ReaMySql資料庫
- 資料庫事務與隔離級別資料庫