mysql 插入数据锁等待超时报错:Lock wait timeout exceeded; try restarting transaction

报错信息

Lock wait timeout exceeded; try restarting transaction

锁等待超时 Lock wait timeout exceeded; try restarting transaction,是当前事务在等待其它事务释放锁资源造成的

解决办法

1、数据库中执行如下sql,查看当前数据库的线程情况:

powershell 复制代码
show full PROCESSLIST

2、再到 INNODB_TRX 事务表中查看,看 trx_mysql_thread_id 是否在 show full processlist 里面的 sleep 线程中(

INNODB_TRX 表的 trx_mysql_thread_id 字段对应 show full processlist 中的Id);如果在,就说明这个 sleep 的线程事务一直没有 commit 或者 rollback,而是卡住了,需要我们手动删除。

powershell 复制代码
select * from information_schema.innodb_trx


如上图,trx_mysql_thread_id 为 10557347

powershell 复制代码
kill  10557347

kill 10557347

相关推荐
難釋懷11 分钟前
Redis命令-Hash命令
数据库·redis·哈希算法
難釋懷14 分钟前
Redis命令-List命令
数据库·redis·list
zqmattack25 分钟前
SQL sever根据身份证判断性别函数
java·数据库·sql
hanqunfeng27 分钟前
(七)Redis 命令及数据类型 -- Hash
数据库·redis·哈希算法
符哥200839 分钟前
基于mysql如何设置一个商城的数据库结构
数据库·mysql·oracle
chuxinweihui40 分钟前
MySQL库数据类型
数据库·mysql
工业HMI实战笔记1 小时前
HMI权限分级设计:兼顾安全与操作效率的平衡术
运维·数据库·安全·ui·自动化·人机交互·交互
为自己_带盐1 小时前
架构演进:从数据库“裸奔”到多级防护
数据库·架构
深蓝电商API1 小时前
Scrapy与MongoDB管道集成:异步存储方案
数据库·scrapy·mongodb