MySQL 中的锁机制

下面从分类体系 + 典型场景 + 面试高频点 三个层次,系统性讲清 MySQL 中的锁机制(以 InnoDB 为主)。


一、按「锁粒度」划分

1. 表级锁(Table Lock)

  • 特点:锁整张表,开销小,并发能力差

  • 常见类型

    • 表共享锁(S)
    • 表排他锁(X)
  • 使用场景

    • MyISAM 引擎(只支持表锁)
    • InnoDB 在 DDL、LOCK TABLES 时使用
sql 复制代码
LOCK TABLE user READ;
LOCK TABLE user WRITE;

2. 行级锁(Row Lock,InnoDB 核心)

  • 特点:锁定记录(或记录区间),并发能力强,开销大
  • 前提必须命中索引
  • 使用场景:OLTP 高并发读写
sql 复制代码
SELECT * FROM user WHERE id = 1 FOR UPDATE;

❗ 未命中索引 → 行锁退化为表锁


3. 页级锁(Page Lock)

  • 特点:锁一页数据,介于表锁和行锁之间
  • 说明:InnoDB 内部使用,对用户不显式暴露(了解即可)

二、按「锁模式」划分

1. 共享锁(S Lock)

  • 读锁
  • 多事务可同时加 S 锁
  • 不允许写
sql 复制代码
SELECT * FROM user WHERE id = 1 LOCK IN SHARE MODE;

2. 排他锁(X Lock)

  • 写锁
  • 加锁事务独占数据
  • 阻塞其他读/写锁
sql 复制代码
SELECT * FROM user WHERE id = 1 FOR UPDATE;

三、InnoDB 特有的三大行锁类型(面试重点)


1. 记录锁(Record Lock)

  • 某一行记录
  • 条件:唯一索引等值查询
sql 复制代码
SELECT * FROM user WHERE id = 10 FOR UPDATE;

2. 间隙锁(Gap Lock)

  • 锁的是 索引区间(不含记录)
  • 防止幻读(插入新行)
  • RR 隔离级别下启用
sql 复制代码
SELECT * FROM user WHERE id BETWEEN 10 AND 20 FOR UPDATE;

3. 临键锁(Next-Key Lock)

  • 记录锁 + 间隙锁
  • InnoDB 默认锁策略(RR)
  • 锁定范围:(prev, current]

作用:彻底防止幻读


四、意向锁(Intent Lock)

表级锁,但为行锁服务

  • IS(意向共享锁)
  • IX(意向排他锁)

作用:快速判断表中是否存在行锁,避免逐行扫描


五、按「使用场景」再分类

1. 自动锁(隐式锁)

  • DML 自动加锁
sql 复制代码
UPDATE user SET name='A' WHERE id=1;

2. 显式锁

sql 复制代码
SELECT ... FOR UPDATE;
LOCK TABLES user WRITE;

六、死锁(Deadlock)

产生条件

  • 互斥
  • 请求与保持
  • 不可剥夺
  • 循环等待

InnoDB 处理方式

  • 自动检测死锁
  • 回滚代价最小的事务
sql 复制代码
SHOW ENGINE INNODB STATUS;

七、锁与事务隔离级别关系

隔离级别 是否使用间隙锁 是否可能幻读
READ UNCOMMITTED
READ COMMITTED
REPEATABLE READ(默认)
SERIALIZABLE 表级锁

八、常见面试高频问题总结

1. 为什么"索引失效会导致锁表"?

行锁是基于索引实现的,未命中索引 → 无法定位行 → 锁整表


2. RR 下如何解决幻读?

Next-Key Lock(记录 + 间隙)


3. RC 与 RR 的锁差异?

  • RC:无 Gap Lock
  • RR:有 Gap / Next-Key Lock

4. MyISAM 与 InnoDB 锁区别?

引擎 锁类型
MyISAM 表锁
InnoDB 行锁 + 表锁

九、一句话总结(面试版)

MySQL InnoDB 通过行锁 + 间隙锁 + 临键锁,在 RR 隔离级别下有效解决幻读问题;锁是否生效,关键看索引是否命中。


相关推荐
Anastasiozzzz6 小时前
MySQL深分页问题与优化思路
数据库·mysql
伯明翰java6 小时前
数据库的操作
数据库
知识分享小能手10 小时前
PostgreSQL 入门学习教程,从入门到精通,PostgreSQL 16 语法知识点与案例详解(1)
数据库·学习·postgresql
康康的AI博客10 小时前
智能情感分析与品牌策略优化:如何通过AI洞察提升企业市场响应力
大数据·数据库·人工智能
Anastasiozzzz10 小时前
阿亮随手记:MySQL移除查询缓存、子查询优化深分页、自增主键溢出、索引失效
数据库·mysql·缓存
ppp今天又没打瓦11 小时前
围达梦数据库批量插入更新性能实测:普通表、一级分区与二级分区的对决
数据库
@insist12311 小时前
软考-数据库系统工程师-计算机体系结构与流水线核心考点解析
数据库·软考·数据系统工程师
可观测性用观测云11 小时前
KES(KingbaseES)数据库监控最佳实践
数据库
新缸中之脑12 小时前
在Reddit上探索未满足的需求
数据库·oracle
安当加密12 小时前
用 SMS 凭据管理系统替代 HashiCorp Vault:中小企业的轻量级 Secrets 管理实践
服务器·数据库·安全·阿里云