概述
-- 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 查看锁表解锁所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复