服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Mysql - Mysql ALTER TABLE加字段的时候到底锁不锁表

Mysql ALTER TABLE加字段的时候到底锁不锁表

2021-09-27 15:42walker_sunxy Mysql

本文主要介绍了Mysql ALTER TABLE加字段的时候到底锁不锁表,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

Mysql5.6版本之前

更新步骤

  • 对原始表加写锁
  • 按照原始表和执行语句的定义,重新定义一个空的临时表。
  • 对临时表进行添加索引(如果有)。
  • 再将原始表中的数据逐条Copy到临时表中。
  • 当原始表中的所有记录都被Copy临时表后,将原始表进行删除。再将临时表命名为原始表表名。
  • 这样的话整个DDL过程的就是全程锁表的。

Mysql5.6版本之后

更新步骤

  • 对原始表加写锁
  • 按照原始表和执行语句的定义,重新定义一个空的临时表。并申请rowlog的空间。
  • 拷贝原表数据到临时表,此时的表数据修改操作(增删改)都会存放在rowlog中。此时该表客户端可以进行操作的。
  • 原始表数据全部拷贝完成后,会将rowlog中的改动全部同步到临时表,这个过程客户端是不能操作的。
  • 当原始表中的所有记录都被Copy临时表,并且Copy期间客户端的所有增删改操作都同步到临时表。再将临时表命名为原始表表名。

总结

ALTER TABLE 加字段会加锁。只是Mysql5.6版本之后新增了ONLINE DDL的功能,可以使该表不能使用的时间大大缩短。

注意

ALTER TABLE 加字段的时候。如果该表的数据量非常大。不要设置default值。
比如,当前有2000万以上数据量的表。如果加字段加了default值。Mysql会执行在执行Online DDL之后,对整个表的数据进行更新默认值的操作,即

?
1
UPDATE `table_name` SET new_col = [默认值] WHERE TRUE

这样就相当于是更新了2000w+的数据,而且是在同一个事务里。也就是说这个事务会把整个表都锁住,直到所有的数据记录都更新完默认值以后,才会提交。

这个时间非常长,而且由于会锁全表的记录,所以该表不可用的时间会非常长。

笔者实验过16核,32G,Mysql默认配置。500w的数据量加一个字段。

不加default值,整个DDL更新过程是66秒。而且整个更新过程,该表的查询、修改、新增操作都是可用的。几乎对该表的可用性没有任何影响。

加default值,整个DDL更新过程是213秒。经过测试,大约在100秒之后,该表的查询、修改、新增操作都会陷入等待状态。

到此这篇关于Mysql ALTER TABLE加字段的时候到底锁不锁表的文章就介绍到这了,更多相关Mysql ALTER TABLE加字段内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://juejin.cn/post/7002180864008257543

延伸 · 阅读

精彩推荐
  • MysqlMySQL 5.7解压版安装、卸载及乱码问题的图文解决方法

    MySQL 5.7解压版安装、卸载及乱码问题的图文解决方法

    这篇文章主要介绍了MySQL 5.7解压版安装、卸载及乱码问题的图文解决方法,本文分步骤给大家介绍的非常详细,需要的朋友可以参考下...

    Crazy_young_man3092020-08-02
  • MysqlMySQL 数据库双向镜像、循环镜像(复制)

    MySQL 数据库双向镜像、循环镜像(复制)

    在MySQL数据库镜像的贴子中,主数据库A 的数据镜像到从数据库B,是单向的,Zen Cart网店的数据读写都必须在数据库A进行,结果会自动镜像到数据库B中。但...

    MYSQL教程网3062019-11-19
  • MysqlMySQL Router的安装部署

    MySQL Router的安装部署

    这篇文章主要介绍了MySQL Router的安装部署,帮助大家更好的理解和学习使用MySQL,感兴趣的朋友可以了解下...

    DBA随笔8562021-06-24
  • Mysql关于mysql delete的问题小结

    关于mysql delete的问题小结

    关于mysql delete的问题,需要的朋友可以参考下。 ...

    MYSQL教程网2292019-11-18
  • Mysqlnavicat 8 for mysql建库的方法

    navicat 8 for mysql建库的方法

    在本篇文章里小编给大家分享的是关于navicat 8 for mysql建库的方法以及相关知识点,需要的朋友们参考学习下。...

    MYSQL教程网5602020-11-28
  • MysqlMySQL语句加锁的实现分析

    MySQL语句加锁的实现分析

    MySQL的加锁分析,一直是一个比较困难的话题。我在工作过程中,经常会有同事咨询这方面的问题。今天我们来简单谈谈这个问题 ...

    笱局长2852020-08-17
  • Mysqlmysql类似oracle rownum写法实例详解

    mysql类似oracle rownum写法实例详解

    在本篇文章里小编给大家分享的是关于mysql类似oracle rownum写法以及相关实例内容,需要的朋友们可以学习下。...

    smileNicky4792020-12-03
  • MysqlMYSQL日期和时间函数不求人

    MYSQL日期和时间函数不求人

    对于每个类型拥有的值范围以及并且指定日期何时间值的有效格式的描述见7.3.6日期和时间类型。 这里是一个使用日期函数的例子。下面的查询选择了所有...

    mysql技术网5292019-10-17