间隙锁的锁定范围
MySQL间隙锁锁定范围测试
- 创建表,添加数据(表名以自己姓名开头防止重复)
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);
- 设置隔离级别为可重复读
SET TRANSACTION ISOLATION LEVEL REPEATABLE READ;
- 开启一个查询事务先不提交
Begin;
UPDATE t SET a = 8 WHERE b = 10;
- 开启一个新的终端进入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操作不会受影响。