mysql锁表、事务锁查询与杀死

提示:使用navicat的mysql修改、删除、新增时卡住,一直转圈,最后找了半天发现是事务锁了。


前言


提示:以下是本篇文章正文内容,下面案例可供参考

一、查询锁表与杀死

  ![状态列为:waiting表示正在执行](https://img-blog.csdnimg.cn/14933ba17c5144839c42f27f4075dfa2.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBAMDAxX21lbW9yeQ==,size_20,color_FFFFFF,t_70,g_se,x_16#pic_center)
//查询被锁的表,状态为waiting表示正在执行,id作为kill参数
show full processlist;
kill 64179
//64179为id

二、查询事务锁与杀死

代码如下:trx_mysql_thread_id为kill的id

select trx_state, trx_started, trx_mysql_thread_id, trx_query from information_schema.innodb_trx
//trx_mysql_thread_id是上面sql查出来的
kill trx_mysql_thread_id;
引用\[1\]:MySQL 排查锁表常用Sql信息查询是否被的表查询innodb事务获取的 查询会话当前会话列表基于IP过滤基于数据库过滤会话详情查询会话执行过的sql 杀死会话杀死指定会话生成杀死某一IP下会话SQL。引用\[2\]:MySQL查看sql 查看数据库状态 # 会显示加的信息等等 show engine innodb status; 查看正在执行的线程信息 show full processlist; 查看正在的表 show open tables where in_use > 0; show open tables; 查看的类型、状态 show status like '%lock%'; 5.0后,增加了3个关于的表 MySQL5.7版本 INFORMATION_SCHEMA.innodb_trx 当前运行的所有事务INFORMATION_SCHEMA.innodb_locks 当前出现的INFORMATION_SCHEMA.innodb_lock_waits 等待的对应关系 MySQL8.0版本。引用\[3\]:8.0后,performance_schema.data_locks代替了INFORMATION_SCHEMA.innodb_locks ,performance_schema.data_lock_waits代替了INFORMATION_SCHEMA.innodb_lock_waits 查看正在事务 SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS; -- 5.7 SELECT * FROM performance_schema.data_locks; -- 8.0 查看等待事务 SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS; -- 5.7 SELECT * FROM performance_schema.data_lock_waits; -- 8.0 查看情况 show status like 'InnoDB_row_lock%'; 查看情况 show status like 'table%'; 开启监控。 问题: mysql查询锁表sql 回答: 要查询MySQL中的锁表信息,可以使用以下SQL语句: - 查看数据库状态,包括加的信息等等: `show engine innodb status;` - 查看正在执行的线程信息: `show full processlist;` - 查看正在的表: `show open tables where in_use > 0;` 或者 `show open tables;` - 查看的类型和状态: `show status like '%lock%';` - MySQL5.7版本及以上,可以使用以下表来查看的信息: - 当前运行的所有事务: `SELECT * FROM INFORMATION_SCHEMA.innodb_trx;` - 当前出现的: `SELECT * FROM INFORMATION_SCHEMA.innodb_locks;` - 等待的对应关系: `SELECT * FROM INFORMATION_SCHEMA.innodb_lock_waits;` - MySQL8.0版本及以上,可以使用以下表来查看的信息: - 当前运行的所有事务: `SELECT * FROM performance_schema.data_locks;` - 等待的对应关系: `SELECT * FROM performance_schema.data_lock_waits;` - 查看情况: `show status like 'InnoDB_row_lock%';` - 查看情况: `show status like 'table%';` - 开启监控: 可以根据具体需求选择合适的监控工具或配置来实现的监控。 #### 引用[.reference_title] - *1* [MySQL 排查锁表常用SQL](https://blog.csdn.net/qq1620657419/article/details/124846298)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [MySQL查看sql](https://blog.csdn.net/blood_Z/article/details/128779095)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值