如何理解 MySQL 事務(wù)中的不可重復(fù)讀和幻讀問題?
問題描述
如何理解 MySQL 事務(wù)中的不可重復(fù)讀和幻讀問題? 或者說 READ COMMIT 和 REPEAT COMMIT 兩種隔離性的區(qū)別在哪?
問題解答
回答1:剛好學(xué)習(xí)一下這個(gè),我就粗淺的來說說我的想法:Read Committed(不可重復(fù)讀):假設(shè)事務(wù)1讀取了一條記錄(select user_name from user where user_id = 1),得到user_name = ’456’,事務(wù)1暫時(shí)沒提交。事務(wù)2更新了一條記錄(update user set user_name = ’123’ where user_id = 1),事務(wù)2提交。此時(shí)事務(wù)1再次select user_name from user where user_id = 1得到了user_name = ’123’,這樣就導(dǎo)致事務(wù)1在讀取同一行數(shù)據(jù)卻得到不同的user_name。這就是所謂的不可以重復(fù)讀
Repeatable Read(可重復(fù)讀,會(huì)產(chǎn)生幻讀):這個(gè)跟不可重復(fù)讀相反,當(dāng)事務(wù)1查詢到user_name=’456’時(shí),事務(wù)2將user_name更新成’123’并提交,事務(wù)1再次查詢還是會(huì)發(fā)現(xiàn)user_name=’456’,這樣保證了可重復(fù)讀。幻讀的話就是當(dāng)事務(wù)2插入一條新的數(shù)據(jù)id為2并提交,事務(wù)1由于可重復(fù)讀的性質(zhì),只能在表中查到id為1的數(shù)據(jù),如果此時(shí)事務(wù)1插入id為2的數(shù)據(jù)則會(huì)產(chǎn)生錯(cuò)誤,因?yàn)榇藭r(shí)表中已經(jīng)有了id為2的數(shù)據(jù),但是事務(wù)1只看到了id為1的數(shù)據(jù)。
相關(guān)文章:
1. javascript - vue 移動(dòng)端的input 數(shù)字輸入優(yōu)化2. 為什么我ping不通我的docker容器呢???3. javascript - 有什么兼容性比較好的辦法來判斷瀏覽器窗口的類型?4. 關(guān)于docker下的nginx壓力測試5. HTML5禁止img預(yù)覽該怎么解決?6. 服務(wù)器端 - 采用nginx做web服務(wù)器,C++開發(fā)應(yīng)用程序 出現(xiàn)拒絕連接請(qǐng)求?7. javascript - npm start 運(yùn)行’webpack-dev-server’報(bào)錯(cuò) Cannot find module ’webpack’8. angular.js - Ionic 集成crosswalk后生成的apk在android4.4.2上安裝失敗???9. java - 靜態(tài)屬性中的賦值和靜態(tài)代碼塊中的賦值有什么區(qū)別?10. javascript - nidejs環(huán)境設(shè)置操作一直出現(xiàn)這種問題怎么解決?
