当前位置:Gxlcms > 数据库问题 > mysql悲观锁中的共享锁和排他锁

mysql悲观锁中的共享锁和排他锁

时间:2021-07-01 10:21:17 帮助过:25人阅读

1排他锁和其他锁不能共存

2innoDB引擎.默认对update,delete,insert加排他锁,select语句默认不加锁

3共享锁可以和其他锁共存

测试:

我们有如下测试数据

技术分享

 

现在我们对id=1的数据行排他查询,这里会使用begin开启事务,而不会看见我关闭事务,这样做是用来测试,因为提交事务或回滚事务就会释放锁。

打开一个查询窗口

技术分享

 

会查询到一条数据,现在打开另一个查询窗口,对同一数据分别使用排他查和共享锁查询两种方式查询

排他查

技术分享

共享查

技术分享

我们看到开了排他锁查询和共享锁查询都会处于阻塞状态,因为id=1的数据已经被加上了排他锁,此处阻塞是等待排他锁释放。

如果我们直接使用以下查询呢

技术分享

我们看到是可以查询到数据的。

我们再看一下一个事务获取了共享锁,在其他查询中也只能加共享锁或不加锁。

技术分享

技术分享技术分享

我们看到是可以查询数据的,但加排他锁就查不到,因为排他锁与共享锁不能存在同一数据上。

最后我们验证下上面说的mysql InnoDb引擎中update,delete,insert语句自动加排他锁的问题,

技术分享

技术分享

此时共享查询处于阻塞,等待排它锁的释放,但是用普通查询能查到数据,因为没用上锁机制不与排他锁互斥,但查到的数据是修改数据之前的老数据。

技术分享

然后我们提交数据,释放排他锁看下修改后的数据,此时可用排他查,共享查和普通查询, 因为事务提交后该行数据释放排他锁,下面就只显示普通查询,其他的同学们自己去验证。

技术分享

技术分享

可以看到结果与预期的一样。


mysql悲观锁中的共享锁和排他锁

标签:.com   gray   space   sha   init   ack   add   height   ini   

人气教程排行