开发者

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

目录
  • 报错信息
  • 解决办法
    • 1、数据库中执行如下sql
    • 2、再到 INNODB_TRX 事务表中查看
  • 总结

    报错信息

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

    Lock wait timeout exceeded; try restarting transaction

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

    解决办法

    1、数据库中执行如下sql

    查看当前数据库的线程情况:

    show full PROCESSLIST

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

    2、再到 INNODB_TRX 事务表中查看

    看 trx_mysql_thread_id 是否在 s编程客栈how full processlist 里面的 sleep 线程中(INNODB_TRX 表的 trx_mysql_thread_id 字段对应 show full processlist 中的Id);

    如果在,就说明这个 sleep 的线程事务一直没有 commit 或者 rollback,而是卡住了,需要我们手动删除。

    select * from information_schema.innodb_trx

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

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

    如上图,trx_mysql_thread_id 为 10557347

    kilhttp://www.devze.coml  10557347

    总结

    以上为个人经验,希望能给大家一个参考,也编程客栈希望大家多多支持编程客栈(www.devze.com)。

    0

    上一篇:

    下一篇:

    精彩评论

    暂无评论...
    验证码 换一张
    取 消

    最新数据库

    数据库排行榜