间隙锁的锁定范围

本文通过实例展示了在MySQL中,当事务使用间隙锁(Gap Lock)时,如何阻止其他事务在锁定范围内进行插入和更新操作,导致阻塞。实验说明了间隙锁对于间隙内操作的限制以及对间隙外操作的允许,强调了事务隔离级别对并发控制的影响。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

间隙锁的锁定范围

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操作不会受影响。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值