当前位置: 首页 > news >正文

说说什么是间隙锁

分析&回答

间隙锁为了解决RR(可重复读)级别下当前读导致的幻读问题,锁的对象是索引叶子节点的next指针。

快照读

在RR隔离级别下:快照读有可能读到数据的历史版本,也有可能读到数据的当前版本。所以快照读无需用锁也不会发生幻读的情况。

当前读

  • 当前读:select…lock in share mode,select…for update
  • 当前读:update,delete,insert
  • 当前读读取的是记录的最新版本,需要通过加锁(行锁、间隙锁、表锁)的方式,使得被当前读读过的数据不能被新增修改或者删除,换句话说再来一次当前读要返回相同的数据。

数据库 X

a 主键b 索引c 字段
12A
36B
54C
710D
98E

间隙锁范围

select c from X where a=4 for update;

会锁住主键索引叶子节点的3的next指针。

select c from X where a=3 for update;

间隙锁会退化为行锁只锁叶子节点3 ,为什么因为没必要。

select c from X where a>4 for update;

叶子节点3及之后所有节点会加行锁并且他们的next指针会加锁,

select a from X where c=2 for update;

会发生锁表,因为c没有索引结构能存储行锁或者间隙锁。

反思&扩展

  • mysql中尽量不要使用区间更新。
  • 需要更新的情况使用 ID = X
  • 查询也尽量通过 ID 去查

喵呜面试助手:一站式解决面试问题,你可以搜索微信小程序 [喵呜面试助手] 或关注 [喵呜刷题] -> 面试助手 免费刷题。如有好的面试知识或技巧期待您的共享!

http://www.lryc.cn/news/161820.html

相关文章:

  • python小题库(三)
  • 【前端设计模式】之单例模式
  • Linux——(第六章)常用指令(一)
  • 第19章_瑞萨MCU零基础入门系列教程之RTC
  • 6、Spring之依赖注入源码解析(上)
  • vscode各种配置的方法
  • 每天几道面试题(第一天)
  • [paddle]paddlepaddle官方安装命令合集
  • 使用JS实现一个简单的观察者模式(Observer)
  • 智能井盖传感器:高效守护城市道路安全
  • pycharm创建py文件时自动添加基础信息--模板
  • Notpad++常用正则表达式替换案例集锦
  • DGA行为转变引发了对网络安全的担忧
  • 微信小程序开发---页面导航
  • torch.nn中的L1Loss和MSELoss
  • Speech | 语音处理,分割一段音频(python)
  • 【深度学习】 Python 和 NumPy 系列教程(三):Python容器:1、列表List详解(初始化、索引、切片、更新、删除、常用函数、拆包、遍历)
  • 【C++笔记】C++string类模拟实现
  • 操作系统之课后习题——引论
  • 【PHP代码审计】反序列化漏洞实战
  • Socks5 与 HTTP 代理在网络安全中的应用
  • 进阶C语言-指针的进阶(中)
  • 保姆级-微信小程序开发教程
  • 数据库-DQL
  • 19 螺旋矩阵
  • 数据结构与算法:概述
  • 顺序表详解
  • 基于RabbitMQ的模拟消息队列之六——网络通信设计
  • 算法:数组中的最大差值---“打擂台法“
  • 三种方式查看 JVM 垃圾收集器