我是靠谱客的博主 从容招牌,最近开发中收集的这篇文章主要介绍mysql查看表被哪个进程锁住_mysql 查看锁表解锁,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

-- mysql 查看锁表解锁

-- 查看那些表锁到了 show open tables where in_use > 0;

-- 查看进程号 show processlist;

-- 删除进程 kill 1085850;

--查询是否锁表

show open tables where in_use > 0;

show open tables;

-- 锁定数据表,避免在备份过程中,表被更新

mysql>lock tables tbl_name read;

-- 为表增加一个写锁定:

mysql>lock tables tbl_name write;

-- 解锁

unlock tables;

--查看表的状态

show status like 'table%';

show status like 'innodb_row_lock%';

注意:该处是锁定为只读状态,语句不区分大小写

1、 #关闭所有打开的表,强制关闭所有正在使用的表,并刷新查询缓存和预准备语句缓存,不会刷新脏块

flush tables

2、#关闭所有打开的表并使用全局读锁锁定所有数据库的所有表,不会刷新脏块

flush tables with read lock;

3、如果一个会话中使用lock tables tbl_name lock_type语句对某表加了表锁,在该表锁未释放前,那么另外一个会话如果执行flush tables语句会被阻塞,执行flush tables with read lock也会被堵塞

4、如果一个会话正在执行ddl语句,那么另外一个会话如果执行flush tables 语句会被阻塞 ,执行flush tables with read lock也会被堵塞

5、如果一个会话正在执行dml大事务(dml语句正在执行,数据正在发生修改,而不是使用lock in share mode和for update语句来显式加锁),那么另外一个会话如果执行flush tables语句会被阻塞,执行flush tables with read lock也会被堵塞

6、flush tables with read lock语句不会阻塞日志表的写入,例如:查询日志,慢查询日志等

7、mysqldump的--master-data、--lock-all-tables参数引发flush tables和flush tables with read lock

8、flush tables tbl_name [, tbl_name] ... for export 会刷新脏块

9、flush tables with read lock可以针对单个表进行锁定,比如只锁定table1则flush tables table1 with read lock;

赞赏

微信赞赏支付宝赞赏

最后

以上就是从容招牌为你收集整理的mysql查看表被哪个进程锁住_mysql 查看锁表解锁的全部内容,希望文章能够帮你解决mysql查看表被哪个进程锁住_mysql 查看锁表解锁所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(48)

评论列表共有 0 条评论

立即
投稿
返回
顶部