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

mysql间隙锁是什么

头像

小妮浅浅

2021-05-18 14:36:251266浏览 · 0收藏 · 0评论

1、说明

当我们用范围条件检索数据,并请求共享或排他锁时,InnoDB会给符合条件的已有数据记录的索引项加锁;对于键值在条件范围内但并不存在的记录,叫做间隙。InnoDB也会对这个间隙加锁,这种锁机制就是所谓的间隙锁。

2、注意

若执行的条件是范围过大,则InnoDB会将整个范围内所有的索引键值全部锁定,很容易对性能造成影响。

3、实例

Transaction-A
mysql> update innodb_lock set k=66 where id >=6;
Query OK, 1 row affected (0.63 sec)
mysql> commit;
 
Transaction-B
mysql> insert into innodb_lock (id,k,v) values(7,'7','7000');
Query OK, 1 row affected (18.99 sec)

以上就是mysql间隙锁的介绍,希望对大家有所帮助。更多编程基础知识学习:python学习网

关注

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

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

底部广告图