执行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,果然又开始嗖嗖地执行了