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;

赞赏

微信赞赏支付宝赞赏

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值