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

MySQL锁分类

一、按锁的粒度划分

  1. 全局锁

    • 定义:锁定整个数据库实例,阻止所有写操作,确保数据备份一致性。
    • 加锁方式:通过FLUSH TABLES WITH READ LOCK实现,释放需执行UNLOCK TABLES
    • 应用场景:适用于全库逻辑备份,但会阻塞所有数据变更。
  2. 表级锁

    • 分类
  • 表锁:分为读锁(共享锁)和写锁(排他锁),由LOCK TABLES ... READ/WRITE显式控制。
  • 元数据锁(MDL) :自动在访问表时添加,防止表结构变更与读写冲突,事务提交后释放。
  • 意向锁:InnoDB特有,分为意向共享锁(IS)和意向排他锁(IX),用于快速判断表中是否有行级锁。
    • 特点:开销小、加锁快,但并发度低,易引发锁冲突。
    • 存储引擎支持:MyISAM仅支持表锁;InnoDB支持表锁与行锁。
  1. 行级锁
    • 实现机制:由InnoDB引擎支持,基于索引实现。若SQL未使用索引,行锁会退化为表锁。
    • 具体类型
  • 记录锁(Record Lock) :锁定单行记录。
  • 间隙锁(Gap Lock) :锁定索引记录间的间隙,防止其他事务插入数据。
  • 临键锁(Next-Key Lock) :记录锁+间隙锁的组合,锁定左开右闭的区间,解决幻读问题。
    • 特点:开销大、加锁慢,可能引发死锁,但并发度高。

二、按锁的属性划分

  1. 共享锁(S锁)

    • 定义:允许其他事务读取但禁止写入。
    • 加锁方式:通过SELECT ... LOCK IN SHARE MODESELECT ... FOR SHARE实现。
    • 应用场景:适用于多事务并发读取同一数据。
  2. 排他锁(X锁)

    • 定义:禁止其他事务读写锁定对象。
    • 加锁方式:通过SELECT ... FOR UPDATE或更新语句(如UPDATE)自动添加。
    • 应用场景:数据修改或需要独占访问的场景。

三、按加锁机制划分

  1. 悲观锁

    • 原理:假定并发冲突必然发生,操作前先获取锁(如共享锁或排他锁)。
    • 实现方式:通过数据库内置锁机制(如FOR UPDATE)实现。
  2. 乐观锁

    • 原理:假定冲突较少,通过版本号或时间戳校验数据是否被修改。
    • 实现方式:使用WHERE条件检查数据版本,若冲突则重试或回滚。
http://www.lryc.cn/news/545027.html

相关文章:

  • DeepSeek 助力 Vue3 开发:打造丝滑的悬浮按钮(Floating Action Button)
  • 认知动力学视角下的生命优化系统:多模态机器学习框架的哲学重构
  • Metal 学习笔记五:3D变换
  • unity学习56:旧版legacy和新版TMP文本输入框 InputField学习
  • 32位,算Cache地址
  • C++蓝桥杯基础篇(六)
  • React 常见面试题及答案
  • 和鲸科技推出人工智能通识课程解决方案,助力AI人才培养
  • 免费使用 DeepSeek API 教程及资源汇总
  • 网络安全-使用DeepSeek来获取sqlmap的攻击payload
  • 网络原理--TCP/IP(2)
  • Ragflow与Dify之我见:AI应用开发领域的开源框架对比分析
  • 文件上传漏洞绕过WAF
  • [含文档+PPT+源码等]精品基于Python实现的vue3+Django计算机课程资源平台
  • Qt 开源音视频框架模块之QtAV播放器实践
  • 【前端】XML,XPATH,与HTML的关系
  • ubuntu服务器安装VASP.6.4.3
  • 市场加速下跌,但监管「坚冰」正在消融
  • 7.2 - 定时器之计算脉冲宽度实验
  • Imagination DXTP GPU IP:加速游戏AI应用,全天候畅玩无阻
  • 关于流水线的理解
  • 采样算法二:去噪扩散隐式模型(DDIM)采样算法详解教程
  • 北京大学DeepSeek提示词工程与落地场景(PDF无套路免费下载)
  • Hutool - POI:让 Excel 与 Word 操作变得轻而易举
  • IDEAPyCharm安装ProxyAI(CodeGPT)插件连接DeepSeek-R1教程
  • Iceberg Catalog
  • 2025年2月个人工作生活总结
  • vscode java环境中文乱码的问题
  • Java数据结构第十五期:走进二叉树的奇妙世界(四)
  • 【MySQL】CAST()在MySQL中的用法以及其他常用的数据类型转换函数