文章詳情頁
mysql自動提交的問題
瀏覽:69日期: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. docker-machine添加一個已有的docker主機問題2. docker綁定了nginx端口 外部訪問不到3. node.js - nodejs debug問題4. docker 下面創建的IMAGE 他們的 ID 一樣?這個是怎么回事????5. docker - 如何修改運行中容器的配置6. docker images顯示的鏡像過多,狗眼被亮瞎了,怎么辦?7. docker網絡端口映射,沒有方便點的操作方法么?8. docker-compose中volumes的問題9. golang - 用IDE看docker源碼時的小問題10. debian - docker依賴的aufs-tools源碼哪里可以找到啊?
排行榜
