间隙锁说明

 innodb引擎自动使用间隙锁来避免幻读(原因是因为innodb采用单行锁+间隙锁组合而成的行锁,会锁定一个范围和记录本身的行),参数默认innodb_locaks_unsafe_for_binlog为false时开启,True时禁用。

间隙锁的缺点

 当高并发访问时执行delete操作和insert操作时,如 

  delete from user u where u.id = 2; insert into user u values(2);

  delete from user u where u.id = 3; insert into user u values(3);

  可能会出现乱序,delete from user u where u.id = 2;delete from user u where u.id = 3;这时当执行最后一条插入语句时就会抛出死锁。

  这时数据库会扫描索引,数据库会向左扫描扫到第一个比给定参数小的值, 向右扫描扫描到第一个比给定参数大的值, 然后以此为界,构建一个区间,

  最终会锁住整个区间内的数据,这就是间隙锁的死锁,这种情况就得修改代码逻辑, 存在才删除,尽量不去删除不存在的记录。

相关文章:

  • 2021-10-09
  • 2021-10-08
  • 2022-12-23
  • 2021-05-24
  • 2022-12-23
猜你喜欢
  • 2022-02-09
  • 2022-01-08
  • 2021-07-07
  • 2021-12-22
  • 2021-10-14
  • 2021-11-05
  • 2021-11-14
相关资源
相似解决方案