mysql innodb的行锁(5) --next-Key 锁

发布时间:2020-08-15 14:04:53 作者:xchui702
阅读:118
mysql云数据库,弹性扩容,低至0.3元/天! 查看>>
间隙锁 next-key, 是针对范围条件不存在的记录上锁,避免不可重复读和幻象读。 如果是 read committed 的隔离级别,则不存在此问题。
所以: 我们在开发中,如果使用 repeatable read的隔离级别,要尽量减少针对一定范围记录的更新,不然会严重影响并发插入。

特例: 通过相等的条件,申请一个不存在的记录的锁,也会使用next-key锁,并影响记录的插入。


root@sakila 10:46:49>show variables like '%tx_isolation%';
+---------------+-----------------+
| Variable_name | Value           |
+---------------+-----------------+
| tx_isolation  | REPEATABLE-READ |
+---------------+-----------------+
1 row in set (0.00 sec)

会话1:
root@sakila 10:49:04>select * from tab_no_index where id=111 for update;
Empty set (0.00 sec)

会话2:  因为第一个会话加锁的记录不存在,所以对 next-key加锁了,没有范围,等于所有,所以插入不了新的记录了
root@sakila 10:47:43>insert into tab_no_index values(200,'200');
ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction
root@sakila 10:49:17>rollback;
Query OK, 0 rows affected (0.01 sec)

亿速云「云数据库 MySQL」免部署即开即用,比自行安装部署数据库高出1倍以上的性能,双节点冗余防止单节点故障,数据自动定期备份随时恢复。点击查看>>

推荐阅读:
  1. IMF前期知识储备-What is Spark详细讲解(四大特性)
  2. zabbix自定义脚本实现短信报警提醒

开发者交流群:

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

原文链接:http://blog.itpub.net/674865/viewspace-2135288/

--next-key innodb mysql

上一篇:给电脑安装硬盘的方法

下一篇:面对疫情,什么样的企业能过关斩将,度过重重考验?

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》
开发者交流群×