use mysql报错_MySQL中存储引擎MyISAM表锁中的读锁和写锁详细案例介绍

msyql锁定义

锁是计算机协调多个进程或线程并发访问某一资源的机制。在数据库中,除传统的计算资源(如CPU、RAM、I/O等) 的争用以外,数据也是一种供许多用户共享的资源。如何保证数据并发访问的一致性、有效性是所有数据库必须解决的一个问题,锁冲突也是影响数据库并发访问性能的一个重要因素。从这个角度来说,锁对数据库而言显得尤其重要,也更加复杂。

锁分类

  1. 从数据库操作类型(读写锁)

读锁:共享锁,针对同一份数据,多个操作可以同时进行而不会相同影响。

写锁:排它锁,当前写操作没有完成,它会阻断其他的读锁或写锁

  1. 从对数据库操作的颗粒分类

表锁:偏读,偏向MyISAM存储引擎,开销小,加锁快,无死锁,锁定颗粒大,发生锁的概率最高,并发度最低

  • 案例说明
mysql> create table lock_01(    -> id int not null primary key auto_increment,    -> name varchar(20)    -> )engine myisam;
2e98e138cfb27d1c5e3042d0e355c4cb.png
#In_use  0:代表没有锁   1:代表锁mysql>show open tables;#查看表是否有锁
e7d333099971346d9da8910d2ac619ae.png
#手动增加表锁mysql>lock table 表名字 read(write), 表二 read(write);#手动解除表锁mysql>unlock tables;
#对lock_01表加读锁mysql>lock table lock_01 read;
9e448d4d4da48a0a19cf81e858ff0b7c.png

对lock_01表加锁

51e374066676727a4d0cf7f634f9f4d6.png

In_use值变成1

cad01f050ee391ae5e415c4127667c61.png
ec5ea23bb4c0098274a93ff56610f2f6.png

MyISAM写锁

#对表lock_01加写锁mysql>lock table lock_01 write;
0a7d21bae353641ee0318b6bf8c021d7.png

MyISAM读锁结论:

1、session1对Test_01库中的lock_01加读锁,对于session2来说都可以查询lock_01,session1也可以对自己加了读锁的表进行查询,但是session1无法对Test_01库中的其他表进行查询和写操作,但session2可以对其他的表进行读写操作,但是对session1加了锁的lock_01表进行写操作时会发生阻塞,直到session1解锁,即session2立即进行写操作。

2、session1加锁,session1只能读自己,其他session能读,写会阻塞

3、session1加锁,session1不能查其他表,直接报错,其他session可以读

4、session1加锁,session1不能修改其他表,直接报错,其他session可以对其他表进行写操作

5、session1加锁,session1不能修改自己,直接报错,其他session写会阻塞

读锁:读共享、写阻塞

MyISAM写锁结论:

写锁:排他,全阻塞

1、session1加锁,session1可以自己读,但不能写,其他session全阻塞

2、session1加锁,session1不能对其他表进行操作,其他session可以进行读写

392b4d3d03465e07e67abbb27a1d0789.png

如何分析表锁定

#可以通过检查table_locks_waited和table_locks_immediate状态变量来分析系统上的表锁定:mysql>show status like 'table%';
2c0b0ce77d9ff24415225e959f0b0896.png

有两个状态变量记录MySQL内部表级锁定的情况,两个变量说明如下:

  • Table_locks_immediate: 产生表级锁定的次数,表示可以立即获取锁的查询次数,每立即获取锁值加1 ;
  • Table_locks_waited: 出现表级锁定争用而发生等待的次数(不能立即获取锁的次数,每等待一次锁值 加1),此值高则说明存在着较严重的表级锁争用情况;

此外,Myisam的读写锁调度是写优先,这也是myisam不适合做写为主表的引擎。因为写锁后,其他线程不能做任何操作,大量的更新会使查询很难得到锁,从而造成永远阻塞

点击关注发私信或评论交流文章中有问题的地方,相互学习和答疑

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值