品易云推流 关闭
文章详情页
文章 > MySQL > mysql间歇锁是什么

mysql间歇锁是什么

头像

小妮浅浅

2021-07-13 15:53:10343浏览 · 0收藏 · 0评论

说明

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

关注

关注公众号,随时随地在线学习

本教程部分素材来源于网络,版权问题联系站长!

底部广告图