Mysql

  1. Mysql并发控制

#Mysql

Mysql并发控制

   假设表中的一行记录,在高并发的情况下,一个在读,另一个试图修改,有可能读的会报错退出,也有可能读到错误的数据,因此需要加锁,解决此问题的经典方法就是读写锁。
  读写锁就是含有两把锁,通常被称为共享锁和排他锁,也叫读锁和写锁。读锁是共享的,读的过程互相不阻塞,而写锁是排他的,在写的过程中会阻塞其他写锁和读锁。

##锁粒度
  加锁的范围尽量只锁定想要锁定的部分数据。因为加锁的数据越小,争锁的几率就越小,系统的并发性就越高。
  加锁本身就是一个耗费资源的操作,包括获得锁,检查锁,释放锁都会增加系统开销,因此说策略,无非就是在资源开销和数据安全性中寻找一个tradeoff。Mysql提供以下两种锁。

  • 表锁
    它会锁定整张表,当在对表进行写操作前,需要先拿到写锁然后阻塞其他用户对该表的所有读写操作,只有没有写锁时,其他读取的用户才能拿到读锁。
  • 行级锁
    行级锁可以最大程度的支持并发处理,在InnoDB和XtrDB中实现了行级锁。

本网站发布的一切文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请联系邮箱:1194325527@qq.com处理

目录
×

给作者杯卡布奇诺

github