说明
1、间隙锁是Innodb在提交下为了解决幻读问题时引入的锁机制。
2、对于键值在条件范围内但并不存在的记录,在相等条件下请求给一个不存在的记录也会加锁,叫做间隙锁。
实例
#session1 操作会话session1 开启事务
mysql> begin;
Query OK, 0 rows affected (0.00 sec)
#session1 更新id=11的数据,获取行锁。
mysql> select * from userinfo where id=11 for update;
Empty set (0.00 sec)
#session2 操作会话session2 开启事务
mysql> begin;
Query OK, 0 rows affected (0.00 sec)
#session2 在会话session2 新增数据主键为12
mysql> insert into userinfo values(12,'hh',18);
.... 一直处于阻塞状态
#如果等待时间过长,session1没有释放锁,会抛出如下异常。
ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction
以上就是mysql间隙锁的介绍,希望对大家有所帮助。更多mysql学习指路:MySQL
推荐操作系统:windows7系统、mysql5.8、DELL G3电脑
收藏 | 0点赞 | 0打赏
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有