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

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

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

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

相关推荐
JH30739 分钟前
【SpringBoot】SpringBoot中使用AOP实现日志记录功能
java·spring boot·后端
anqi2742 分钟前
在sheel中运行Spark
大数据·开发语言·分布式·后端·spark
程序员小刚1 小时前
基于SpringBoot + Vue 的作业管理系统
vue.js·spring boot·后端
问道飞鱼2 小时前
【Springboot知识】Springboot计划任务Schedule详解
java·spring boot·后端·schedule
o0o0o0D3 小时前
jmeter 执行顺序和组件作用域
后端
神仙别闹3 小时前
基于ASP.NET+MySQL实现待办任务清单系统
后端·mysql·asp.net
程序员buddha3 小时前
【Spring Boot】Spring Boot + Thymeleaf搭建mvc项目
spring boot·后端·mvc
okok__TXF5 小时前
spring详解-循环依赖的解决
java·后端·spring
二十雨辰7 小时前
[学成在线]23-面试题总结
java·后端
神马都会亿点点的毛毛张7 小时前
【SpringBoot教程】SpringBoot自定义注解与AOP实现切面日志
java·spring boot·后端·spring·spring aop·aspectj