mysql---MySQL的字典锁

✅什么是MySQL的字典锁?

字典锁,英文名叫做MetaData Lock,也叫做MDL锁

字典锁,英文名叫做MetaData Lock,也叫做MDL锁,它是一种用于管理元数据的锁机制,而不是数据本身的锁。

MDL锁用于控制对数据库对象的元数据的并发访问,数据库会在执行DDL(Data Defination Language)操作时加上字典锁。字典锁的主要目的是保护数据库中的元数据对象,如表、列、索引、视图等,以确保在DDL操作期间,不会出现数据一致性问题和竞争条件。

以下是触发数据库加字典锁的一些情况:

  • 1.创建/修改/删除表结构:当执行CREATE TABLE、ALTER TABLE、DROP TABLE等DDL语句时,数据库会对相关的表和表的元数据对象加上字典锁,以阻止其他事务同时修改这些表的结构。

  • 2.创建/修改/删除索引:执行CREATE INDEX、ALTER TABLE 添加索引、修改、删除索引等DDL操作时,会锁定与索引相关的元数据,以确保索引的一致性。

  • 3.修改列定义:如果执行ALTER TABLE来修改表的列定义,例如改变数据类型、添加、删除、重命名列等,相关的列和表的元数据会被锁定。

  • 4.创建/修改/删除视图:当执行CREATE VIEW、ALTER VIEW、DROP VIEW等DDL操作以创建或修改视图时,相关视图的元数据会被锁定。

  • 5.其他DDL操作:其他的DDL操作,如创建、修改、删除存储过程、触发器、事件等也可能涉及到元数据的锁定。

字典锁升级

在数据库中,通常有两种主要的锁级别,即共享锁和排他锁,而字典锁也有两种级别,即:

  • 1.共享字典锁(SHARED-MDL ):这允许多个事务同时读取元数据对象,但不允许任何事务修改它们。共享字典锁通常用于保护元数据的读取操作,以确保在读取元数据时不会被其他事务修改。

  • 2.排他字典锁(EXCLUSIVE-MDL ):排他字典锁是最高级别的字典锁,它阻止其他事务同时读取或修改元数据对象。只有一个事务可以持有排他字典锁,通常用于保护元数据的写操作,以确保数据的完整性。

而在字典锁的加锁过程中,会有升级的情况,当事务开始时,通常会以共享字典锁的方式访问元数据对象。这允许多个事务同时读取相同的元数据。

如果事务需要对元数据对象进行修改操作,例如修改表结构或索引,它需要将共享字典锁升级为排他字典锁,以阻止其他事务同时访问该元数据对象。

在数据库管理系统中,升级通常是自动执行的。当事务尝试修改元数据对象时,系统会检测到需要升级共享字典锁为排他字典锁,以确保数据的完整性。

相关推荐
卜锦元10 分钟前
Golang项目开发过程中好用的包整理归纳(附带不同包仓库地址)
开发语言·后端·golang
Tony Bai4 小时前
“我曾想付钱给 Google 去工作”—— Russ Cox 深度访谈:Go 的诞生、演进与未来
开发语言·后端·golang
serendipity_hky6 小时前
【SpringCloud | 第2篇】OpenFeign远程调用
java·后端·spring·spring cloud·openfeign
嘟嘟MD6 小时前
程序员副业 | 2025年11月复盘
后端·创业
SadSunset6 小时前
(15)抽象工厂模式(了解)
java·笔记·后端·spring·抽象工厂模式
汝生淮南吾在北6 小时前
SpringBoot+Vue养老院管理系统
vue.js·spring boot·后端·毕业设计·毕设
李慕婉学姐6 小时前
【开题答辩过程】以《基于springboot的地铁综合服务管理系统的设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
java·spring boot·后端
期待のcode7 小时前
Springboot配置属性绑定
java·spring boot·后端
海上彼尚7 小时前
Go之路 - 6.go的指针
开发语言·后端·golang
LYFlied7 小时前
在AI时代,前端开发者如何构建全栈开发视野与核心竞争力
前端·人工智能·后端·ai·全栈