MySQL中的"可重復讀"是指在一個事務的范圍內,同一查詢將返回相同的結果,不受其他并發(fā)事務的影響。這也是MySQL默認的隔離級別。
SET TRANSACTION ISOLATION LEVEL REPEATABLE READ;
在可重復讀的隔離級別下,MySQL會對查詢的結果進行緩存,即MVCC (多版本并發(fā)控制),從而避免了在事務執(zhí)行過程中讀取到其他事務更新的數據。因此,在可重復讀模式下,同一事務中的查詢語句不會對數據進行加鎖,只有更新數據的語句會對數據進行加鎖。
但是,需要注意的是,可重復讀并不能完全解決并發(fā)的問題。例如,在可重復讀的事務A中,如果另一個事務B對A需要查詢的數據進行更新,而B的更新操作還沒有提交,那么A查詢到的數據是過時的。為了解決這個問題,MySQL提供了鎖機制,可以通過鎖定行或表的方式來避免并發(fā)問題。
如果我們需要在事務中讀取最新的數據,可以使用 "SELECT ... FOR UPDATE" 或 "SELECT ... LOCK IN SHARE MODE",來獲取行或表的共享或排他鎖。
SELECT * FROM table_name WHERE condition FOR UPDATE; SELECT * FROM table_name WHERE condition LOCK IN SHARE MODE;
總結來說,可重復讀提供了一種機制來保證事務執(zhí)行的一致性和隔離性,但是需要開發(fā)人員在實際應用中根據具體的業(yè)務場景,選擇合適的隔離級別和鎖機制來處理并發(fā)問題。
下一篇eizo vue鞋