mysql执行报错:Lock wait timeout exceeded问题解决

执行insert语句时报错“Lock wait timeout exceeded”

遇到的原因是因为同时对表进行了插入/更新操作导致这样的报错,继续查明原因是:上周五下班前执行了批量插入数据的脚本,脚本执行到一半不执行了,也没报错,通过下面这个命令:

show  PROCESSLIST;

发现有个commit进程已经执行了57小时还没结束,我想大概是他的原因,于是kill掉:

kill connection id;

继续执行没执行完的insert,发现“Lock wait timeout exceeded”这个报错不出现了,但是

又出现了没反应的情况,继续用show  PROCESSLIST;查询发现,commit进程又出现了,而且时间不断增加,先kill掉这个进程

于是灵机一动,查询了一下binlog日志:

show binary logs;

发现果然很多,于是怒而删除:

purge binary logs to 'binlog.000231'; 

-- 在这个binlog.000231日志之前的日志全部删除

删完之后继续执行insert,果然又开始嗖嗖地执行了

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

αβ阿邦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值