Linux 拨号vps windows公众号手机端

MySQL修改字段长度不锁表的方法是什么

lewis 9年前 (2016-12-07) 阅读数 8 #VPS/云服务器
文章标签 mysql

MySQL修改字段长度不锁表的方法有以下两种:

  1. 使用 ALTER TABLE 命令修改字段长度,并使用 ALGORITHM=INPLACELOCK=NONE 参数。例如:
ALTER TABLE table_name ALGORITHM=INPLACE, LOCK=NONE MODIFY COLUMN column_name varchar(255);

这种方法可以在线上环境进行字段长度的修改,不会锁定整个表,但是需要 MySQL 版本在 5.6.17 以上。

  1. 使用 pt-online-schema-change 工具进行在线表结构变更。pt-online-schema-change 是 Percona Toolkit 工具集中的一个工具,它可以在不锁定表的情况下进行表结构变更。首先需要安装 Percona Toolkit 工具集,然后使用以下命令进行字段长度的修改:
pt-online-schema-change --alter "MODIFY COLUMN column_name varchar(255)" D=database_name,t=table_name

这种方法会创建一个新的临时表,将数据逐渐从原表复制到临时表,期间可以正常读写数据,最后再将原表重命名为备份表,将临时表重命名为原表,完成表结构的变更。

版权声明

本文仅代表作者观点,不代表米安网络立场。

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

热门