Mysql(1)并发控制

1、读写锁

读锁是共享锁,相互不阻塞的。

写锁是排他锁,一个写锁会阻塞其他的写锁和读锁。

2、锁粒度

所谓的锁策略,就是在锁的开销和数据的安全性之间寻求平衡,这种平衡当然也会影响到性能。大多数商用数据库系统没有提供更多的选择,一般都是在表上施加行级锁,并加以各种复杂的方式来实现,以便在锁比较多的情况下尽可能地提供更好的性能。

Mysql每种存储引擎都可以实现自己的锁策略和锁粒度。


锁策略一:表锁

表锁是Mysql中最基本的锁策略,并且开销是最小的。一个用户对表进行写操作前,需要先获取写锁,这会阻塞其他用户对表的写和读操作。

        写锁也比读锁有更高的优先级,因此一个写锁请求可能会被插入到读锁队列的前面

        尽管存储引擎可以管理自己的锁,mysql本身还是会使用各种有效的表锁来实现不同的目的。例如,服务器会为诸如alter table之类的语句使用表锁,而忽略存储引擎的锁机制。


锁策略二:行级锁

行级锁可以最大程度地支持并发处理,同时也带来 最大的锁开销。行级锁只在存储引擎层实现,而mysql服务器层没有实现。服务器层完全不了解存储引擎的锁实现。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值