MySQL 中有哪几种锁?

在 MySQL 中,锁机制用于控制并发访问,以保证数据的一致性和完整性。主要有以下几种锁类型:

1. 表级锁(Table Lock)

  • 读锁(共享锁):允许多个会话并发读取表的数据,但不允许写操作。读锁之间不会互相阻塞。
  • 写锁(排他锁):获得写锁的会话独占该表,阻止其他会话的读和写操作。只有当前会话释放锁后,其他会话才能访问该表。

表级锁简单易用,锁开销小,但并发性较低,适用于读多写少的应用。

2. 行级锁(Row Lock)

  • 只锁定访问的行,而不影响同一表中的其他行。
  • 共享锁(S 锁):允许多个事务并发读取同一行数据,但不能对其进行修改。
  • 排他锁(X 锁):禁止其他事务读取或修改同一行数据。

行级锁的并发性更高,但开销和管理复杂度较大,适用于高并发的写操作环境。InnoDB 引擎默认使用行级锁。

3. 页级锁(Page Lock)

  • 锁定数据所在的数据页,每页包含多个行。
  • 页级锁的开销介于表级锁和行级锁之间,适用于并发度适中且数据量较大的场景。

页级锁主要用于BDB存储引擎,InnoDB 不使用这种锁。

4. 意向锁(Intention Lock)

  • 是 InnoDB 中的一种内部锁,意在表级锁和行级锁之间增加协调层次。
  • 意向共享锁(IS):事务打算在表的某几行上加共享锁时,先申请 IS 锁。
  • 意向排他锁(IX):事务打算在表的某几行上加排他锁时,先申请 IX 锁。

意向锁提高了锁的性能,避免表级和行级锁的冲突检测时扫描整个表。

5. 自增锁(AUTO-INC Lock)

  • 专用于自增字段,保证多个事务在并发插入时生成唯一的自增值。
  • MySQL 使用一种轻量级的表锁来保证自增值的唯一性。

6. 间隙锁(Gap Lock)

  • InnoDB 特有,用于 Next-Key Locks 机制中,锁定一个范围的索引,防止其他事务在该范围内插入数据。
  • 间隙锁用于解决幻读问题,确保事务的一致性。
相关推荐
瑶总迷弟1 分钟前
使用 Docker 和 docker-compose 快速部署 openGauss
linux·数据库·云原生·eureka
C.R.xing17 分钟前
Pyspark分布式访问NebulaGraph图数据库
数据库·分布式·python·pyspark·nebulagraph
九皇叔叔20 分钟前
深度解析 PostgreSQL 中的 ctid、xmin、xmax:从原理到实战
数据库·postgresql
殷丿grd_志鹏32 分钟前
开源项目RuoYi-Cloud-Plus详解——公网内网穿透到虚拟机环境(持续更新)
数据库·开源·内网穿透·虚拟机
知其然亦知其所以然41 分钟前
面试官问:MySQL表损坏怎么修?不会这三招你就凉了!
后端·mysql·面试
木易 士心1 小时前
AI 在数据库操作中的各类应用场景、方案与实践指南
数据库·人工智能·oracle
SunsPlanter1 小时前
苍穹外卖--04--Redis 缓存菜品信息、购物车
数据库·redis·缓存
解决问题no解决代码问题2 小时前
oracle删除表与表空间清理机制
数据库·oracle
洲覆2 小时前
Redis 事务机制:Pipeline、ACID、Lua脚本
数据库·redis·缓存·lua
CHHC18802 小时前
SQLite批量操作优化方案
数据库·sqlite