MySQL中有哪几种锁?

MySQL 支持多种类型的锁,用于控制对数据的并发访问,以避免并发事务中的问题。以下是 MySQL 中常用的几种锁:

1. 表级锁(Table Locks)

表级锁是最简单的锁类型,它作用于整个表。MyISAM 和 InnoDB 存储引擎都支持表级锁。

MyISAM 表锁:MyISAM 存储引擎使用表锁,它会在读取表时锁定整个表,在读取过程中阻止其他事务对表的修改操作。MyISAM 支持读写锁,但只允许一个事务在同一时间修改表。
InnoDB 表锁:InnoDB 存储引擎也支持表级锁,但在大部分情况下,InnoDB 默认使用行级锁,只有在特定情况下才会使用表级锁。

2. 行级锁(Row Locks)

行级锁是最细粒度的锁类型,它作用于表中的单个行。InnoDB 存储引擎支持行级锁,这是 InnoDB 相比 MyISAM 的一大优势。

InnoDB 行锁:InnoDB 存储引擎使用行锁来提高多行操作的并发性。行锁可以确保同一时刻只有一个事务可以更新或删除特定行,而其他事务可以同时读取同一行。

3. 页级锁(Page Locks)

页级锁是介于表级锁和行级锁之间的锁类型,它作用于表中的一个或多个页。InnoDB 存储引擎支持页级锁。

InnoDB 页锁:InnoDB 存储引擎使用页锁来提高多页操作的并发性。当一个事务修改数据时,它可能会锁定整个页,以防止其他事务对该页中的其他行进行修改。

4. 意向锁(Intention Locks)

意向锁是一种特殊的表级锁,它用于标记一个事务是否打算在某个范围内对行进行读取或修改。InnoDB 存储引擎支持意向锁。

InnoDB 意向锁:意向锁可以确保一个事务不会与其他事务发生冲突。当一个事务想要在某个范围内对行进行读取或修改时,它会先获取该范围的意向锁。

5. 排他锁(Exclusive Locks)

**排他锁也称为 X 锁,它确保一个事务可以独占性地访问数据。**当一个事务持有排他锁时,其他事务不能读取或修改该数据。InnoDB 存储引擎支持排他锁。

InnoDB 排他锁:排他锁是 InnoDB 存储引擎中最严格的锁类型。当一个事务持有排他锁时,其他事务不能读取或修改被锁定的数据。

6. 共享锁(Shared Locks)

共享锁也称为 S 锁,它允许多个事务同时读取数据,但不能修改。InnoDB 存储引擎支持共享锁。

InnoDB 共享锁:共享锁允许多个事务同时读取数据,这有助于提高多读操作的并发性。当一个事务持有共享锁时,其他事务也可以获取共享锁,但它们不能获取排他锁。

通过合理地使用这些锁类型,可以有效地控制并发事务,避免并发事务带来的问题,从而提高 MySQL 数据库的性能和稳定性。

相关推荐
摩羯座-185690305948 小时前
爬坑 10 年!京东店铺全量商品接口实战开发:从分页优化、SKU 关联到数据完整性闭环
linux·网络·数据库·windows·爬虫·python
编程充电站pro9 小时前
SQL 面试高频:INNER JOIN vs LEFT JOIN 怎么考?
数据库·sql
这周也會开心9 小时前
SQL-窗口函数做题总结
数据库·sql
间彧9 小时前
TiDB详解与Spring Boot实战指南
数据库
极限实验室9 小时前
Easysearch 字段'隐身'之谜:source_reuse 与 ignore_above 的陷阱解析
数据库·redis
2301_772093569 小时前
tuchuang_后端_前端_注册登录
数据库·后端·网络协议·mysql·wireshark
K_i1349 小时前
中国电信用户行为实时分析系统运维实战
hadoop·mysql
武子康10 小时前
Java-141 深入浅出 MySQL Spring事务失效的常见场景与解决方案详解(3)
java·数据库·mysql·spring·性能优化·系统架构·事务
间彧10 小时前
脏读、不可重复读、幻读详解与对比
数据库
间彧10 小时前
数据库事务隔离级别详解
数据库