Myisam中的锁实战—如何验证读写锁

一、Myisam中的锁

Myisam中有读锁与写锁。只有表锁,无行锁。

那么也就是其中只有表级的行锁与表级的写锁。

我们可以通过命令来模拟上锁与解锁的过程。

二、上锁

读锁:

lock table a read;

写锁:

lock table a write;

三、解锁

unlock tables;

四、查询锁

show open tables;
show open tables where in_use >= 1;
show open tables where `table` = 'a';

查询出来的字段含义:

database:含有该表的数据库。

table:表名称。

in_use:如果为1,表面正在被使用中,也就是在锁中,如果为0,表明表打开中,但是当前没有被使用。

name_locked:表名称是否被锁定,名称锁定用于取消表或者表进行重命名。

五、锁的区别

对表上读锁,其他线程或进程可以读这个表,但是写这个表需要等待

对表上写锁,其他线程或进程读这个表需要等待写这个表也需要进行等待

六、Myisam机制

Myisam在执行查询之前,会自动给对应的表加读锁。

在执行增删改前,会自动给对应的表加写锁。

七、总结

读锁会阻塞写,但是不会阻塞读。写锁会把读和写都阻塞掉。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值