MySQL:lock wait timeout exceeded; try restarting transactio解决方案

错误提示的意思,很明显,是因为这条语句被锁住了。所以释放这个锁
我们可以到information_schema中查询

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

我们可以用下面三张表来查原因:
       innodb_trx 当前运行的所有事务
       innodb_locks  当前出现的锁
       innodb_lock_waits  锁等待的对应关系
  • 查看数据库锁id
    在这里插入图片描述
  • 图中红色语句为占用系统资源的语句,我们需要杀掉这个锁,执行 kill 线程id号。上面这条记录的id为319618246
    所以我们执行:kill 319618246即可
    执行之后:
    在这里插入图片描述
    其他的记录不需要关注,因为其他的记录状态为“RUNNING” 即正在执行的事务,并没有锁

扩展:表结构

desc information_schema.innodb_locks;

FieldTypeNullKeyDefaultRemark
lock_idvarchar(81)NO锁ID
lock_trx_idvarchar(18)NO拥有锁的事务ID
lock_modevarchar(32)NO锁模式
lock_typevarchar(32)NO锁类型
lock_tablevarchar(1024)NO被锁的表
lock_indexvarchar(1024)YESNULL被锁的索引
lock_spacebigint(21) unsignedYESNULL被锁的表空间号
lock_pagebigint(21) unsignedYESNULL被锁的页号
lock_recbigint(21) unsignedYESNULL被锁的记录号
lock_datavarchar(8192)YESNULL被锁的数据

desc information_schema.innodb_lock_waits

FieldTypeNullKeyDefaultRemark
requesting_trx_idvarchar(18)NO请求锁的事务ID
requested_lock_idvarchar(81)NO请求锁的锁ID
blocking_trx_idvarchar(18)NO当前拥有锁的事务ID
blocking_lock_idvarchar(81)NO当前拥有锁的锁ID

desc information_schema.innodb_trx ;

FieldTypeNullDefaultRemark
trx_idvarchar(18)NO事务ID
trx_statevarchar(13)NO事务状态:
trx_starteddatetimeNO0000-00-00 00:00:00事务开始时间;
trx_requested_lock_idvarchar(81)YESNULLinnodb_locks.lock_id
trx_wait_started datetimeYESNULL事务开始等待的时间
trx_weightbigint(21) unsignedNO0#
trx_mysql_thread_id bigint(21) unsignedNO0事务线程ID
trx_query varchar(1024)YESNULL具体SQL语句
trx_operation_statevarchar(64)YESNULL事务当前操作状态
trx_tables_in_usebigint(21) unsignedNO0事务中有多少个表被使用
trx_tables_lockedbigint(21) unsignedNO0事务拥有多少个锁
trx_lock_structsbigint(21) unsignedNO0#
trx_lock_memory_bytesbigint(21) unsignedNO0事务锁住的内存大小(B)
trx_rows_lockedbigint(21) unsignedNO0事务锁住的行数
trx_rows_modifiedbigint(21) unsignedNO0事务更改的行数
trx_concurrency_ticketsbigint(21) unsignedNO0事务并发票数
trx_isolation_levelvarchar(16)NO事务隔离级别
trx_unique_checksint(1)NO0是否唯一性检查
trx_foreign_key_checksint(1)NO0是否外键检查
trx_last_foreign_key_errorvarchar(256)YESNULL最后的外键错误
trx_adaptive_hash_latchedint(1)NO0#
trx_adaptive_hash_timeoutbigint(21) unsignedNO0#
posted @ 2020-04-26 10:11  叶落无蝉鸣  阅读(78)  评论(0编辑  收藏  举报