zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    路由
    更改HTTP头信息
    laravel 笔记
    laraven安装记录
    虚拟机Centos设置静态IP
    关于正向代理,反向代理,负载均衡的个人理解
    exce族函数详解
    【C】多线程编程笔记
    【转】Linux C 网络编程——TCP套接口编程
    MySQL 用户管理及权限管理
  • 原文地址:https://www.cnblogs.com/kcxg/p/10912697.html
Copyright © 2011-2022 走看看