亲宝软件园·资讯

展开

关于navicat事务自动提交问题

夜神月写日记 人气:5
这篇文章主要介绍了关于navicat事务自动提交问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

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

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

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

show variables like 'autocommit

查看事务是否自动提交

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

set autocommit=on;

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

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

首先查看MySQL设置:

show variables like 'autocommit';

结果应为:

在这里插入图片描述

然后执行:

set autocommit = 0;
delete from table1 where id =xxx;
commit; or rollback;

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

在这里插入图片描述

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

加载全部内容

相关教程
猜你喜欢
用户评论