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

MySQL:顿悟‌了,添加索引时竟然不锁表?

一、前言

  在 MySQL 数据库中,“锁表” 指的是对数据库表进行锁定,以控制对表中数据的并发访问。锁表是数据库管理系统(DBMS)用来维护数据一致性和完整性的一种机制。

  当某个事务(Transaction)或操作需要对表中的数据进行修改(如 INSERT、UPDATE、DELETE)时,它可能会请求锁定该表或表的一部分,以防止其他事务同时访问或修改相同的数据,从而导致数据不一致或冲突。

  那么,在创建索引时一定会锁表吗?

二、Online DDL

  MySQL 的 Online DDL(Data Definition Language)技术允许在不中断数据库服务的情况下执行表结构的变更操作。这意味着你可以在数据库正在运行并处理查询的同时,添加索引、修改列类型、添加或删除列等操作。
  传统的 DDL 操作会锁定表,导致在变更期间无法进行读写操作,而 Online DDL 则大大减少了这种锁定时间,提高了数据库的可用性。

  在MySQL 5.6 及更高版本中,InnoDB 存储引擎支持在线添加索引(即使用 Online DDL),这通常意味着在添加索引时不会锁定整个表,从而允许并发读写操作。

Online DDL 的关键参数

ALGORITHM
  INPLACE: 尽可能在原地修改表结构,不创建临时表。
  COPY: 创建临时表,然后复制数据到新表,最后替换旧表。
  DEFAULT: 由 MySQL 自动选择最佳算法。

LOCK
  NONE: 尽可能不锁定表,允许读写操作。
  SHARED: 锁定表,只允许读操作。
  EXCLUSIVE: 锁定表,不允许读写操作。
  DEFAULT: 由 MySQL 自动选择最佳锁定级别。

代码示例

ALTER TABLE my_table 
ADD INDEX idx_my_column (my_column), 
ALGORITHM=INPLACE, 
LOCK=NONE;

注意事项:
  性能影响:虽然 Online DDL 减少了锁定时间,但在执行期间仍可能对性能产生一定影响,尤其是在大数据量的表上。
  事务支持:在 InnoDB 中,Online DDL 操作通常是事务性的,但某些操作可能无法回滚。
  限制:某些类型的表结构变更(如改变主键)可能无法使用 Online DDL。

三、总结

  在 MySQL 5.6 之前,创建索引时会锁表,但在 MySQL 5.6.7 之后,因为新增了 Online DDL 技术,所以此时在添加索引时,是可以和 DML 数据操作语言 INSERT、UPDATE、DELETE、SELECT 等命令一起执行的。


http://www.kler.cn/a/454438.html

相关文章:

  • 【Java 数据结构 】反转一个单链表
  • Visual Studio2019基础使用指南
  • 每天40分玩转Django:实操多语言博客
  • Day53 图论part04
  • Stable Diffusion绘画 | 电商设计海报
  • hhdb客户端介绍(57)
  • 7种server的服务器处理结构模型
  • lv_ffmpeg学习及播放rtsp
  • VS Code AI开发之Copilot配置和使用详解
  • 基于Javaee的影视创作论坛的设计与实现【源码+文档+部署讲解】
  • 【C++面向对象——类的多态性与虚函数】编写教学游戏:认识动物(头歌实践教学平台习题)【合集】
  • SpringCloud2023集成Nacos2.4.3
  • redis与aerospike性能及数据结构对比与分析
  • Python 自动化 打开网站 填表登陆 例子
  • 设计模式01:创建型设计模式之单例、简单工厂的使用情景及其基础Demo
  • CTFshow-SSRF文件上传
  • PDF书籍《手写调用链监控APM系统-Java版》第6章 链路的架构(Trace+TraceSegment+Span)
  • SQL进阶技巧:如何分析工厂制程顺序问题?
  • GXUOJ-算法-第一次作业
  • Mysql数据究竟是如何存储的