查看: 22|回复: 0

[综合] 关于navicat事务自动提交问题

[复制链接]

2

主题

0

回帖

0

积分

热心网友

金币
0
阅读权限
220
精华
0
威望
0
贡献
0
在线时间
0 小时
注册时间
2009-3-5
发表于 2023-7-14 00:00:00 | 显示全部楼层 |阅读模式

最近在使用navicat编辑数据库表的时候遇到了一些问题,记录下~~
问题:编辑完数据之后点击“✔”提交的时候navicat卡了,然后提示“mysql lock wait timeout exceeded”,截图现在没有了,总之意思就是超时了。

原因:后来查了好多资料,原来是navicat的自动提交事务关闭了,导致了修改数据之后事务一直未提交,所以再修改数据的时候就得等之前的事务,但是事务一直未提交,所以就超时了

解决原因:可以先看一下事务是否是自动提交的。

?
1
show variables like 'autocommit

关于navicat事务自动提交问题

如图,如果查出来是on,表明事务是自动提交的,修改数据之后不用自己提交。如果是off的话,就需要把自动提交先先打开了。

?
1
set autocommit=on;

这样的话再修改数据的时候就不出出现超时的问题了~~~

ps:下面看下navicat premium 设置update和delete操作不自动提交事务的问题

首先查看mysql设置:

?
1
show variables like 'autocommit';

结果应为:

关于navicat事务自动提交问题

然后执行:

?
1
2
3
set autocommit = 0;
delete from table1 where id =xxx;
commit; or rollback;

 

这时再查询:show variables like ‘autocommit'; 其结果应为:

关于navicat事务自动提交问题

需要注意:这种操作设置,在当前查询窗口有效,重新打开navicat或者新建查询页都需要重新设置。

到此这篇关于navicat事务自动提交问题的文章就介绍到这了,更多相关navicat事务自动提交内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

原文链接:https://blog.csdn.net/yeshenyuexieriji/article/details/105367630

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

相关侵权、举报、投诉及建议等,请发 E-mail:qiongdian@foxmail.com

Powered by Discuz! X5.0 © 2001-2026 Discuz! Team.

在本版发帖返回顶部