文章詳情頁
mysql自動提交的問題
瀏覽:92日期:2022-06-20 10:25:38
問題描述
我使用的mysql5.5自動提交是默認打開的。現在在終端執行一條事物。
begin;update user set username=’Lee’ where id=1;
按說這條事物是自動commit的才對啊,因為默認是自動提交。為什么不是自動的commit,還是在等待人工commit。
mysql的事物發現有個問題,我開啟事物,然后insert一條數據,沒有commit。然后select,發現這條數據竟然已經加進去了,這是什么鬼,在沒commit之前數據不應該在內存里的么。
然后我執行rollback。再試圖開啟事物insert一條數據,commit。這時候不對了,新產生的id應該是上一條回滾的那條id才對啊,為什么是+1了呢。
問題解答
回答1:開啟事務必須手動提交,詳情見我寫的一篇事務隔離級別文章
回答2:吐槽一下,是事務,不是事物……1、你已經手動打開了事務,事務在你控制之下,所以你必須手動提交才會生效,回滾同理;2、MySQL默認的事務隔離級別是RR級,所以可以讀到同一事務內的數據;3、自增id不受事務影響,不論成功提交還是失敗回滾,都會自增,參考資料;
其實對于這三個問題,我也只是知其然不知其所然,但這些問題都可以通過搜索引擎得到答案。
回答3:自動提交是不寫begin,事務的概念沒有搞清楚,搜索有很多答案。
回答4:先把錯別字改了。
相關文章:
1. angular.js - angularjs的自定義過濾器如何給文字加顏色?2. angular.js - angular內容過長展開收起效果3. 關于docker下的nginx壓力測試4. docker鏡像push報錯5. 關于nginx location配置的問題,root到底是什么6. linux - openSUSE 上,如何使用 QQ?7. 并發模型 - python將進程池放在裝飾器里為什么不生效也沒報錯8. 大家好,請問在python腳本中怎么用virtualenv激活指定的環境?9. python的前景到底有大?如果不考慮數據挖掘,機器學習這塊?10. linux - 升級到Python3.6后GDB無法正常運行?
排行榜
