文章詳情頁
數據庫 - mysql如何處理數據變化中的事務?
瀏覽:218日期:2022-06-14 13:16:41
問題描述
有以下兩個事務同時commit:A: 讀取余額,減掉50,提交更新數據庫B: 讀取余額,加上50,提交數據庫
假設A,B兩事務同時提交,mysql如何保證最終結果正確?mysql默認隔離級別為可重復讀,那么就有可能A讀到余額100元,然后更新到50;此時B執行,B執行完成。此時庫為150;A再提交的話就成了50,B的更新被覆蓋。。我的這個理解方式哪里有問題?mysql如何解決這個問題?
問題解答
回答1:事務這塊在程序控制,一般不要數據庫自己的事務機制
回答2:select for update,上鎖,效果就是A或B其中一個讀了余額,另外一個等待鎖讀不了余額,也就不會有后續的并發寫。
回答3:你這個不屬于事務,事務是用來處理多個事件的添刪改
而你這個屬于并發。。。
只是修改一條數據,不需要使用事務,像你說的同時就會耗性能
相關文章:
1. javascript - sublime快鍵鍵問題2. 實現bing搜索工具urlAPI提交3. javascript - 移動端上不能實現拖拽布局嗎?4. boot2docker無法啟動5. thinkPHP5中獲取數據庫數據后默認選中下拉框的值,傳遞到后臺消失不見。有圖有代碼,希望有人幫忙6. 前端 - 這段代碼一直生效不了,查半天因為 top: 0px; 分號后一個隱藏的東西,也不是占位符...刪了就可以生效,這是什么情況。。7. angular.js - 單頁應用(ng/vue)該如何監聽用戶離開當前頁面(或者路由)?8. nginx bind failed9. javascript - 如何判斷不同兩個對象觸發同一事件?10. javascript - react native在run-android時出現這個錯誤該怎么解決?大神賜教
排行榜

網公網安備