小編給大家分享一下怎么解決navicat事務自動提交遇到的問題,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
創(chuàng)新互聯(lián)是一家專業(yè)提供甕安企業(yè)網(wǎng)站建設,專注與做網(wǎng)站、網(wǎng)站制作、H5建站、小程序制作等業(yè)務。10年已為甕安眾多企業(yè)、政府機構等服務。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站制作公司優(yōu)惠進行中。
最近在使用navicat編輯數(shù)據(jù)庫表的時候遇到了一些問題,記錄下~~
問題:編輯完數(shù)據(jù)之后點擊“?”提交的時候navicat卡了,然后提示“MySQL Lock wait timeout exceeded”,截圖現(xiàn)在沒有了,總之意思就是超時了。
原因:后來查了好多資料,原來是navicat的自動提交事務關閉了,導致了修改數(shù)據(jù)之后事務一直未提交,所以再修改數(shù)據(jù)的時候就得等之前的事務,但是事務一直未提交,所以就超時了
解決原因:可以先看一下事務是否是自動提交的。
show variables like 'autocommit
如圖,如果查出來是ON,表明事務是自動提交的,修改數(shù)據(jù)之后不用自己提交。如果是OFF的話,就需要把自動提交先先打開了。
set autocommit=on;
這樣的話再修改數(shù)據(jù)的時候就不出出現(xiàn)超時的問題了~~~
ps:下面看下Navicat Premium 設置update和delete操作不自動提交事務的問題
首先查看MySQL設置:
show variables like 'autocommit';
結果應為:
然后執(zhí)行:
set autocommit = 0; delete from table1 where id =xxx; commit; or rollback;
這時再查詢:show variables like ‘a(chǎn)utocommit'; 其結果應為:
需要注意:這種操作設置,在當前查詢窗口有效,重新打開Navicat或者新建查詢頁都需要重新設置。
以上是“怎么解決navicat事務自動提交遇到的問題”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道!