间隙锁的锁定范围

间隙锁的锁定范围

MySQL间隙锁锁定范围测试

  1. 创建表,添加数据(表名以自己姓名开头防止重复)
create table t(
 a int ,
 b int ,
 primary key(a),
 key(b)
)engine=innodb;

INSERT INTO `t`(`a`, `b`) VALUES (1, 1);
INSERT INTO `t`(`a`, `b`) VALUES (3, 3);
INSERT INTO `t`(`a`, `b`) VALUES (5, 5);
INSERT INTO `t`(`a`, `b`) VALUES (9, 30);
INSERT INTO `t`(`a`, `b`) VALUES (11, 10);
  1. 设置隔离级别为可重复读
SET TRANSACTION ISOLATION LEVEL REPEATABLE READ;
  1. 开启一个查询事务先不提交
Begin;
UPDATE t SET a = 8 WHERE b = 10;
  1. 开启一个新的终端进入MySQL执行插入语句
Begin;
insert into t(a, b) VALUES (8,5);#阻塞
insert into t(a, b) VALUES (7,5); #阻塞
insert into t(a, b) VALUES (10,5); #阻塞
insert into t(a, b) VALUES (4,5); #成功

** 综上:
如果事务(Session1)产生了间隙锁(Gap Lock),那么其他事务(Session2)对间隙中进行insert/update操作,需要先获取排他锁(X),导致阻塞。在间隙外的insert/update操作不会受影响。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值