执行sql报lock wait timeout exceeded; try restarting transaction

mysql查询时候报错:

Lock wait timeout exceeded; try restarting transaction 

译文:锁等待超时;试着重新启动事务
被锁了,需要解锁。
1.innodb_trx 当前运行的所有事务

select * from information_schema.innodb_trx;

查询trx_state的状态
trx_state:
LOCAK WAIT 占用系统资源的语句(事务状态)
RUNNING 即正在执行的事务,并没有锁
#查询线程

SELECT * from information_schema.processlist;

#杀死线程

kill 738178711杀死进程

#查询线程

SHOW FULL processlist;

2.innodb_locks 当前出现的锁

select * from information_schema.innodb_locks;

3.innodb_lock_waits 锁等待的对应关系

select * from information_schema.innodb_lock_waits;

#可以查找执行线程用时比较久的线程,然后直接干掉

SELECT * from information_schema.processlist WHERE Time > 1000 ORDER BY TIME desc;

#查看最近死锁的日志

show engine innodb status;
posted @   sowler  阅读(463)  评论(0编辑  收藏  举报  
相关博文:
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
点击右上角即可分享
微信分享提示