MySQL中大数据表增加字段,通过增加索引实现
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MySQL中大数据表增加字段,通过增加索引实现,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1822字,纯文字阅读大概需要3分钟。
内容图文
![MySQL中大数据表增加字段,通过增加索引实现](/upload/InfoBanner/zyjiaocheng/508/4a1e2fc9923b486c83e3f58a560cc70b.jpg)
普通的添加字段sql
ALTER TABLE `table_name`
ADD COLUMN `num` int(10) NOT NULL DEFAULT 0 AFTER `addtime`;
普通的添加索引sql
ALTER TABLE `table_name` ADD INDEX `num` (`num`) ;
但是线上的一张表如果数据量很大呢,执行加字段操作就会锁表,这个过程可能需要很长时间甚至导致服务崩溃,那么这样操作就很有风险了。
在网上查找的给 MySQL 大表加字段的思路如下:
①创建一个临时的新表,首先复制旧表的结构(包含索引)
②给新表加上新增的字段
③把旧表的数据复制过来
④删除旧表,重命名新表的名字为旧表的名字
实现过程大概就是这样,下面我会附带我实现的sql:
① 创建一个临时的新表,首先复制旧表的结构(包含索引)
create table new_table like old_table;
② 给新表加上新增的字段 增加索引
ALTER TABLE `table_name`
ADD COLUMN `num` int(10) NOT NULL DEFAULT 0 AFTER `addtime`;
ALTER TABLE `table_name` ADD INDEX `num` (`num`) ;
③ 把旧表的数据复制过来
insert into new_table(id,name,content,addtime) select id,name,content,addtime from old_table;
注意:执行这步的时候,可能这个过程也需要时间,这个时候有新的数据进来,所以原来的表如果有字段记录了数据的写入时间就最好了,可以找到执行这一步操作之后的数据,并重复导入到新表,直到数据差异很小。不过还是会可能损失极少量的数据。所以,如果表的数据特别大,同时又要保证数据完整,最好停机操作。选取的一个低峰期时间操作的,减少数据差距。
④ 旧表的名字修改为别的名,重命名新表的名字为旧表的名字
留一个备用表,可以等新表完全没问题再删除
总结:
一般情况下,十几万的数据量,可以直接进行加字段操作。如果这个表数据量太大所以需要其他方法操作。以上就是关于在MySQL大表中加字段加索引的实现思路和步骤。
参考地址:http://www.jb51.net/article/103692.htm
MySQL中大数据表增加字段,通过增加索引实现
标签:line insert tab 过程 link container html_ mysql creat
本文系统来源:https://www.cnblogs.com/kcxg/p/10912697.html
内容总结
以上是互联网集市为您收集整理的MySQL中大数据表增加字段,通过增加索引实现全部内容,希望文章能够帮你解决MySQL中大数据表增加字段,通过增加索引实现所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。