当前位置:首页 > 技术分析 > 正文内容

Mysql修改表结构、添加索引会锁表吗?从MySQL5.7和8.0版本解析

ruisui884周前 (04-01)技术分析17

在使用MySQL时,有时需要修改表结构或添加索引来优化性能,但这些操作是否会锁表一直是一个争议的话题。本文将从MySQL5.7和MySQL8.0两个版本的角度来探讨这个问题。

先上结论

在MySQL5.7和MySQL8.0中,表结构修改和索引添加通常不会锁定整个表。但是,在某些情况下,MySQL可能需要锁定整个表。如果使用ALTER TABLE语句添加索引,则将锁定表。相反,如果使用CREATE INDEX语句添加索引,则不会锁定表。在MySQL8.0中,还引入了“Invisible Indexes”、“Instant DDL”和“In-Place Alter”升级等新功能,可以进一步提高MySQL的性能和可维护性。在进行表结构修改和索引添加时,需要根据具体情况选择合适的方法,以避免对MySQL的性能产生负面影响。

MySQL5.7版本

在MySQL5.7中,对于表结构修改和索引添加,MySQL使用了一种称为“In-Place Alter”的技术。这种技术允许在不锁定表的情况下进行修改。In-Place Alter使用了一种称为“Fast Index Creation”的技术来优化索引添加,它可以在不拷贝原始表数据的情况下创建新索引。

对于表结构修改,MySQL5.7使用了一种称为“Online DDL”的技术。Online DDL允许在不锁定表的情况下进行表结构修改。当修改表结构时,MySQL会创建一个新表,并将原始表中的数据复制到新表中。在复制数据期间,原始表仍然可读和可写。完成数据复制后,MySQL会将新表重命名为原始表的名称,并删除原始表。此过程通常只需要几秒钟或几分钟,并且可以在应用程序运行期间执行。

虽然In-Place Alter和Online DDL可以减少对表的锁定,但它们并不适用于所有情况。例如,在进行某些类型的表结构修改时,MySQL可能需要锁定整个表。在这种情况下,In-Place Alter和Online DDL可能不适用。

此外,在MySQL5.7中,如果使用ALTER TABLE语句添加索引,将会锁定表。但是,如果使用CREATE INDEX语句添加索引,则不会锁定表。这是因为CREATE INDEX语句使用了“Concurrent Inserts”的技术,它允许在不锁定表的情况下进行索引添加。Concurrent Inserts在索引添加期间允许其他并发操作,从而减少了锁定的需求。

综上所述,在MySQL5.7中,表结构修改和索引添加通常不会锁定整个表。但是,在某些情况下,MySQL可能需要锁定整个表。此外,如果使用ALTER TABLE语句添加索引,则会锁定表。相反,如果使用CREATE INDEX语句添加索引,则不会锁定表。

MySQL8.0版本

MySQL8.0在表结构修改和索引添加方面引入了一些新的功能。其中最重要的功能是“Invisible Indexes”和“In-Place Alter”升级。

“Invisible Indexes”允许您创建不会影响查询执行计划的索引。这些索引对于实时修改和测试查询计划非常有用。此外,如果某个索引不再需要,您可以将其设置为“不可见”,而不是完全删除它。这可以减少表锁定的时间,因为在删除可见索引之前不需要锁定整个表。

“In-Place Alter”在MySQL8.0中进行了升级,可以处理更多类型的表结构修改。例如,现在可以在不锁定表的情况下添加、删除和更改列。如果使用In-Place Alter进行表结构修改,则MySQL将创建一个新的表,将新表中的数据与原始表中的数据进行同步,然后在删除原始表之前将新表重命名为原始表的名称。

在MySQL8.0中,索引添加的行为与MySQL5.7相同。如果使用ALTER TABLE语句添加索引,则将锁定表。相反,如果使用CREATE INDEX语句添加索引,则不会锁定表。使用“Concurrent Inserts”技术添加索引可以避免表锁定,这使得索引添加变得更加高效。

此外,在MySQL8.0中,还引入了“Instant DDL”功能。这种功能允许您在不锁定表的情况下执行某些DDL操作,例如添加、删除和更改列,以及更改表类型和重命名表。这可以显著提高MySQL的可用性和可维护性。

综上所述,在MySQL8.0中,表结构修改和索引添加的锁定行为与MySQL5.7大致相同。如果使用ALTER TABLE语句添加索引,则将锁定表。相反,如果使用CREATE INDEX语句添加索引,则不会锁定表。使用In-Place Alter进行表结构修改可以避免锁定整个表。此外,MySQL8.0引入了“Invisible Indexes”、“Instant DDL”和“In-Place Alter”升级等新功能,可以进一步提高MySQL的性能和可维护性。

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/3228.html

标签: 查看表索引
分享给朋友:

“Mysql修改表结构、添加索引会锁表吗?从MySQL5.7和8.0版本解析” 的相关文章

2024最新版:前端性能优化方案汇总

前端训练营:1v1私教,终身辅导计划,帮你拿到满意的 offer。 已帮助数百位同学拿到了中大厂 offer。欢迎来撩~~~~~~~~Hello,大家好,我是 Sunday。前端性能优化一直是很多同学非常关注的问题,在日常的面试中也是经常会被问到的点。所以今天咱们就花一点时间来了解一下2024最新的...

雅马哈TMAX 560 TECH MAX 外媒深度测评

应雅马哈(Yamaha)的邀请,在葡萄牙埃斯托里尔对全新的Yamaha TMAX 560 Tech Max踏板车进行了测试,在这里TMAX 560 Tech Max售价为11649英镑。雅马哈TMAX长期以来一直站在踏板车的顶端,就声誉和知名度而言,它是当之无愧的大踏板界NO.1。2020 TMAX...

你感动了吗?佳能超规格镜头 RF 24-105mm F2.8深度测评

如果要你选一支用作多题材创作的挂机镜头,那我相信很多人会选择24-105mm这个焦段的镜头。作为一支可以实现从广角到长焦的变焦镜头,24-105mm有着丰富的焦段选择。只是基于镜头体积以及光学结构上的限制,此前的24-105mm镜头只能恒定在F4的光圈。而佳能打破了这一限制,将实用焦段和恒定光圈完美...

《暗黑破坏神 2:重制版》PC 版 2.3 版本发布,支持英伟达 DLSS

IT之家 12 月 3 日消息,暴雪为《暗黑破坏神 2:重制版》PC 版发布了更新 2.3 版本,添加了“离线难度缩放”滑块(玩家可以在单人游戏时增加挑战和奖励的级别)、多项辅助功能和用户界面改进,以及英伟达 DLSS 支持。玩法改进:玩家现在可以在离线游戏的选项菜单中使用“游戏难度等级”,它提供与...

Python中的11 种数组算法

1. 创建数组 创建数组意味着留出一个连续的内存块来存储相同类型的元素。在大多数语言中,您可以在创建数组时指定数组的大小。假设您正在书架上整理一组书籍,并且您需要为正好 10 本书预留空间。功能架上的每个空间都对应于数组中的一个索引。# Example in Python arr = [1, 2,...

VUE 技术栈

官网链接:https://cn.vuejs.org/什么是vue:渐进式JavaScript 框架vue-cli链接:https://cli.vuejs.org/vue-cli安装:npm install -g @vue/clivue -V创建一个项目:vue create xxxxxx模版语法:文...