MySql 加意向锁_mysql插入意向锁测试

1、表结构

CREATE TABLE `reno` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`name` varchar(10) DEFAULT NULL,

PRIMARY KEY (`id`)

) ENGINE=InnoDB AUTO_INCREMENT=112 DEFAULT CHARSET=utf8

2、表数据

insert into reno select 5, 'aa';

insert into reno select 7, 'bb';

insert into reno select 9, 'cc';

insert into reno select 18, 'dd';

insert into reno select 23, 'ee';

insert into reno select 30, 'ff';

insert into reno select 40, 'gg';

insert into reno select 45, 'hh';

insert into reno select 99, 'ii';

3、两种尝试

下面两种方案都会造成阻塞,我理解都是事务1获取到了间隙锁,事务2获取插入意向锁阻塞,但是“show engine INNODB status\G;”输出结果不一样,

第一种方案

事务1 lock_mode X locks gap before rec 我理解是间隙锁

事务2 lock_mode X locks gap before rec insert intention waiting 我理解是获取插入意向锁

第二种方案

事务1  trx id 9821 lock_mode X 我理解是 Next key锁

事务2 lock_mode X insert intention waiting 我理解是获取插入意向锁

我的疑问 为什么两个方案,事务1获取的锁,以及事务2获取的锁都是不一样的呢

35aef467c9ff

35aef467c9ff

第一种方案

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL中的间隙锁(Gap Lock)是为了防止并发事务操作时出现幻读(Phantom Read)而引入的一种并发控制机制。在某些特定的情况下,MySQL会为一个范围(间隙)内的记录创建一个间隙锁,以确保其他事务不能在这个范围内插入新的记录。 在MySQL中,插入意向锁(Intention Lock)是在执行插入操作之前,事务会先获取一个意向锁来表明其意图要在特定范围进行插入操作。这个特定范围可以是一个表或者一个索引的间隙,也可以是一个索引记录。插入意向锁主要用于多粒度锁定(multi-granularity locking)策略中。在该策略中,锁定的粒度可以是表、页、行或者间隙,用于提高并发性能。 插入意向锁的前提是必须先存在一个间隙锁。这是因为间隙锁的目的是保护范围内的记录不受其他事务的干扰,而插入意向锁则是在间隙锁的基础上,更精确地告知其他事务自己的意图。因此,在插入操作之前,必须先获取一个间隙锁,然后再取得插入意向锁。这种多层次的锁定机制可以确保在并发操作中,插入操作不会出现幻读。 需要注意的是,MySQL只有在使用了可重复读(REPEATABLE READ)或者串行化(SERIALIZABLE)隔离级别时才会使用间隙锁和插入意向锁。在其他隔离级别下,MySQL会使用其他的并发控制机制来避免幻读,而不是依靠间隙锁和插入意向锁
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值