髒讀-幻讀-不可重複讀

髒讀:(同時操作都沒提交的讀取)

髒讀又稱無效數據讀出。一個事務讀取另外一個事務還沒有提交的數據叫髒讀。

例如:事務T1修改了一行數據,但是還沒有提交,這時候事務T2讀取了被事務T1修改後的數據,之後事務T1因爲某種原因Rollback了,那麼事務T2讀取的數據就是髒的。

解決辦法:把數據庫的事務隔離級別調整到READ_COMMITTED

不可重複讀:(同時操作,事務一分別讀取事務二操作時和提交後的數據,讀取的記錄內容不一致)

不可重複讀是指在同一個事務內,兩個相同的查詢返回了不同的結果。

例如:事務T1讀取某一數據,事務T2讀取並修改了該數據,T1爲了對讀取值進行檢驗而再次讀取該數據,便得到了不同的結果。 解決辦法:把數據庫的事務隔離級別調整到REPEATABLE_READ

幻讀:(和可重複讀類似,但是事務二的數據操作僅僅是插入和刪除,不是修改數據,讀取的記錄數量前後不一致)

例如:系統管理員A將數據庫中所有學生的成績從具體分數改爲ABCDE等級,但是系統管理員B就在這個時候插入(注意時插入或者刪除,不是修改))了一條具體分數的記錄,當系統管理員A改結束後發現還有一條記錄沒有改過來,就好像發生了幻覺一樣。這就叫幻讀。

解決辦法:把數據庫的事務隔離級別調整到SERIALIZABLE_READ

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章