mysql间歇锁指的是什么
发表于:2024-11-25 作者:热门IT资讯网编辑
编辑最后更新 2024年11月25日,这篇文章主要讲解了"mysql间歇锁指的是什么",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"mysql间歇锁指的是什么"吧!说明1、间隙锁是Innod
这篇文章主要讲解了"mysql间歇锁指的是什么",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"mysql间歇锁指的是什么"吧!
说明
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间歇锁指的是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!