zoukankan      html  css  js  c++  java
  • Lock wait timeout exceeded; try restarting transaction解决方法

    最近在使用Mysql查询语句时,出现了Lock wait timeout exceeded; try restarting transaction错误,在进行查阅后再次做下记录

    Lock wait timeout exceeded; try restarting transaction错误的意思是这条语句被锁住了,需要重新执行事务

    解决方法:

    通过information_schema表来进行查找被锁的语句。information_schema这张数据表保存了MySQL服务器所有数据库的信息。如数据库名,数据库的表,表栏的数据类型与访问权限等。再简单点,这台MySQL服务器上,到底有哪些数据库、各个数据库有哪些表,每张表的字段类型是什么,各个数据库要什么权限才能访问,等等信息都保存在information_schema表里面。

    以下三张表可以用来查看原因:

    • innodb_trx 当前运行的所有事务
    • innodb_locks 当前出现的锁
    • innodb_lock_waits 锁等待的对应关系

    innodb_trx表的字段说明:

    desc information_schema.innodb_trx;

     

    通过以下语句来查看正在执行的事务:

    select * from information_schema.innodb_trx

    结果如下:

    记录trx_mysql_thread_id号,发现trx_state的状态为RUNNING,说明事务正在进行,没有锁,但是可能由于sql复杂影响查询效率,sql一直处于运行状态

    通过kill 28166 命令来杀掉mysql线程

    杀掉线程后可以继续查询是否成功:

    SELECT * from information_schema.processlist WHERE id = 28166;

    发现成功杀死了线程

     杀死成功后,就应该考虑率下SQL优化或者SQL的复杂程度了,尽量来减少执行时间!!!

     

  • 相关阅读:
    学英语+运动
    污染的城市
    初识 Microsoft Word
    拿到我人生中的第一张信用卡
    Advanced SharePoint Services Solutions
    DBCC DBREINDEX重建索引提高SQL Server性能【转载】
    Web cast: SharePoint Portal Server Web Part开发 [Resource]
    What's new on site Web Part for SPS [Free]
    Building Web Parts for SPS读书笔记(1)
    SharePoint Products and Technologies 2003 Software Development Kit (SDK)
  • 原文地址:https://www.cnblogs.com/zhukf/p/13367801.html
Copyright © 2011-2022 走看看