髒讀:(同時操作都沒提交的讀取)
髒讀又稱無效數據讀出。一個事務讀取另外一個事務還沒有提交的數據叫髒讀。
例如:事務T1修改了一行數據,但是還沒有提交,這時候事務T2讀取了被事務T1修改後的數據,之後事務T1因爲某種原因Rollback了,那麼事務T2讀取的數據就是髒的。
解決辦法:把數據庫的事務隔離級別調整到READ_COMMITTED
不可重複讀:(同時操作,事務一分別讀取事務二操作時和提交後的數據,讀取的記錄內容不一致)
不可重複讀是指在同一個事務內,兩個相同的查詢返回了不同的結果。
例如:事務T1讀取某一數據,事務T2讀取並修改了該數據,T1爲了對讀取值進行檢驗而再次讀取該數據,便得到了不同的結果。 解決辦法:把數據庫的事務隔離級別調整到REPEATABLE_READ
幻讀:(和可重複讀類似,但是事務二的數據操作僅僅是插入和刪除,不是修改數據,讀取的記錄數量前後不一致)
例如:系統管理員A將數據庫中所有學生的成績從具體分數改爲ABCDE等級,但是系統管理員B就在這個時候插入(注意時插入或者刪除,不是修改))了一條具體分數的記錄,當系統管理員A改結束後發現還有一條記錄沒有改過來,就好像發生了幻覺一樣。這就叫幻讀。
解決辦法:把數據庫的事務隔離級別調整到SERIALIZABLE_READ