• MySQL中大数据表增加字段,增加索引实现


    MySQL中大数据表增加字段,通过增加索引实现

    普通的添加字段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

  • 相关阅读:
    想要快速上手 Spring Boot?看这些教程就足够了!| 码云周刊第 81 期
    Eclipse Java注释模板设置详解以及版权声明
    java跨域解决
    微信公众号创建
    Java与JS生成二维码与条形码
    Java基础break、continue语句的用法
    分布式文件系统介绍
    Hadoop的RPC机制及简单实现
    RPC简介与hdfs读过程与写过程简介
    JVM的Client模式与Server模式
  • 原文地址:https://www.cnblogs.com/kcxg/p/10912697.html
Copyright © 2020-2023  润新知