文章詳情頁
mysql自動提交的問題
瀏覽:94日期: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:先把錯別字改了。
相關文章:
排行榜
