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

相关推荐
LabVIEW开发18 分钟前
LabVIEW数据库使用说明
数据库·sql·labview知识
Python智慧行囊1 小时前
Python Django 的 ORM 编程思想及使用步骤
数据库·python·django·orm
苹果酱05671 小时前
Golang中的runtime.LockOSThread 和 runtime.UnlockOSThread
java·vue.js·spring boot·mysql·课程设计
南方以南_1 小时前
【云实验】Excel文件转存到RDS数据库
数据库·excel
万山y3 小时前
es快速上手(从MySQL角度)
mysql·elasticsearch·jenkins
Listennnn3 小时前
Neo4j数据库
数据库·人工智能·neo4j
Liu1bo3 小时前
【MySQL】库与表的操作
数据库·mysql·oracle
冬瓜的编程笔记4 小时前
【MySQL成神之路】MySQL常用语法总结
数据库·mysql
YJQ99674 小时前
Redis配置与优化:提升NoSQL数据库性能的关键策略
数据库·redis·nosql
@Turbo@4 小时前
【QT】一个界面中嵌入其它界面(二)
开发语言·数据库·qt