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

【MySQL】MySQL中锁有哪些?

一、按照粒度分类:

粒度越小,并发度越高,锁开销越大。

1.全局锁:

  • 作用: 锁定整个MySQL实例(所有数据库)。
  • 适用场景: 全库逻辑部分。(确保备份期间数据的一致性。)
  • 实现方式: 通过 FLUSH TABLES WITH READ LOCK (FTWRL) 命令实现,加锁后所有表变为只读,更新、删除、插入等操作会被阻塞。
  • 注意:InnoDB可通过 mysqldump --single-transaction 结合事务隔离级别避免使用全局锁(利用MVCC实现一致性读)。

2.表级锁:

作用: 锁定整个表,粒度较大,并发度低,但锁开销较小。

  • 适用场景: MyISAM存储引擎默认锁机制(InnoDB也支持,但更常用行锁),适合读多写少的场景。

  • 类型:

    • 表读锁: 多个事务可以加读锁,允许读表,但阻塞写操作(包括加写锁)。
    • 表写锁: 一个事务加锁后,独占表阻塞其他所有读锁和写锁。
  • 特点: MyISAM写锁优先级高于读锁,可能导致读请求饿死(一直等待写锁释放)。

3.行级锁:

  • 作用: 锁定单行记录,粒度最小,并发度最高,锁开销最大。
  • 适用场景: InnoDB存储引擎的核心锁机制,适合写操作频繁的场景(如电商订单、库存更新)。
  • 类型:
    • 行读锁: 事务对某行加读锁后,其他事务可以加读锁,但不能加写锁。
    • 行写锁: 事务对某行加锁后,其他事务不能加读锁或写锁。
  • 特点:InnoDB的行锁基于索引实现,若查询未命中索引,会升级为表锁。

二、按锁的功能划分:

1.共享锁(Shared Lock,S锁):

  • 又称: 读锁。
  • 特性: 多个事务可以同时持有同一资源的S锁,允许读操作,但阻塞写操作(X锁)。
  • 加锁方式:SELECT ... LOCK IN SHARE MODE (InnoDB 中,显式加读锁)。

2.排他锁(Exclusive Lock X锁):

  • 又称写锁。
  • 特性:一个事务持有X锁后,其他事务不能持有该资源的S锁或X锁,独占资源用于写操作。
  • 加锁方式SELECT ... FOR UPDATE;(InnoDB 中,显式加写锁);默认情况下,UPDATE/DELETE/INSERT 会自动加 X 锁。

三、InnoDB特有的锁(基于事务和索引):

1.意向锁:

  • 作用: 表级锁,用于标识”事务稍后会对表中的行加S锁或X锁“,避免表锁与行锁的冲突检查效率问题。
  • 类型:
    • 意向共享锁(Intention Shared Lock IS锁): 事务计划对表中的某些行加S锁,加行S锁前需要先加IS锁。
    • 意向排他锁(IX锁): 事务计划对表中的某些行加X锁,加行X锁前需要先加IX锁。

2.记录锁:

  • 作用: 锁定索引记录本身(具体某一行),防止其他事务修改或删除该记录。
  • 示例: WHERE id=10 id是主键,InnoDB会锁定id=10的这一行。

3.间隙锁:

  • 作用:锁定索引记录之间的"间隙",不包括记录本身,防止其他事务在间隙中插入新纪录。(解决"幻读"问题)。
  • 适用场景:InnoDB的RR隔离级别(默认级别)。
  • 示例:表中id=5、10,WHERE id BETWEEN 5 AND 10 ,会锁定(5,10)之间的间隙,阻止插入id=6、7等记录。

4.临建锁:

  • 作用记录锁+间隙锁的组合,锁定索引记录以及前面的间隙(左开右闭),是InnoDB RR级别下默认的行锁方式。
  • 示例:表中id=5、10,WHERE id=10会锁定 (5,10] 区间。
http://www.lryc.cn/news/608786.html

相关文章:

  • ethtool,lspci,iperf工具常用命令总结
  • 26李林880高数第一章 函数、极限、连续
  • Shell脚本-变量的定义规则
  • 西门子PLC基础指令4:输出指令、立即输出指令
  • JavaScript 性能优化实战指南:从运行时到用户体验的全面提升​
  • adb 与pad 交互方法
  • MyBatis动态SQL精要:从<if>到<foreach>的灵活拼接之道
  • Go语言声明变量
  • 怎么修改论文格式呢?提供一份论文格式模板
  • 【Bluedroid】btif_av_handle_event 流程源码解析
  • 面向智能体的上下文工程:策略、实现与 LangGraph 实践
  • LangChain4J入门:接入大模型
  • 系统学习算法:专题十六 字符串
  • 第三章-提示词-高级:开启智能交互新境界(13/36)
  • 日常--详细介绍qt Designer常用快捷键(详细图文)
  • 【QT】概述
  • 高质量数据集|建设三大难点
  • 01.MySQL 安装
  • 服务器中切换盘的操作指南
  • Android 之 MVVM架构
  • 使用 Docker 部署 Golang 程序
  • 第四章:OSPF 协议
  • Dify中自定义工具类的类型
  • WebMvc自动配置流程讲解
  • MySQL 索引失效的场景与原因
  • 嵌入式开发学习———Linux环境下IO进程线程学习(二)
  • 04.Redis 的多实例
  • 笔试——Day27
  • 前端面试手撕题目全解析
  • 【数据迁移】Windows11 下将 Ubuntu 从 C 盘迁移到 D 盘