zoukankan      html  css  js  c++  java
  • Mysql数据库大表添加字段方法

    1. 直接添加字段

    ALTER TABLE my_table ADD name VARCHAR(64) DEFAULT '' COMMENT '名字' ;

    方法适合十几万的数据量,可以直接进行加字段操作,但是,线上的一张表如果数据量很大,执行加字段操作就会锁表,这个过程可能需要很长时间甚至导致服务崩溃,那么这样操作就有风险。

    2. 临时表方式

    ① 创建一个临时的新表,首先复制旧表的结构(包含索引);

    create table my_table_copy like my_table;

    ② 给新表加上新增的字段,注意,此时新表是空表,加字段很快;

    ③ 复制旧表数据到新表;

    insert into my_table_copy(id,age) select id,age from my_table;

    ④ 删除旧表,重命名新表的名字为旧表的名字

    不过这里需要注意,执行第三步的时候,可能这个过程也需要时间,这个时候有新的数据进来,所以原来的表如果有字段记录了数据的写入时间就最好了,可以找到执行这一步操作之后的数据,并重复导入到新表,直到数据差异很小。不过还是会可能损失极少量的数据。

    所以,如果表的数据特别大,同时又要保证数据完整,最好停机操作。

    3. 使用pt-online-schema-change

    3.1 介绍

    pt-online-schema-change是percona公司开发的一个工具,在percona-toolkit包里面可以找到这个功能,它可以在线修改表结构

    3.2 原理

    • 首先它会新建一张一模一样的表,表名一般是_为前缀_new后缀,例如原表为t_user 临时表就是_t_user_new
    • 然后在这个新表执行更改字段操作
    • 然后在原表上加三个触发器,DELETE/UPDATE/INSERT,将原表中要执行的语句也在新表中执行
    • 最后将原表的数据拷贝到新表中,然后替换掉原表

    SQL语句:

    ALTER TABLE tmp_task_user ADD support tinyint(1) unsigned NOT NULL DEFAULT '1';

    工具命令:

    sh pt.sh tmp_task_user "ADD COLUMN support tinyint(1) unsigned NOT NULL DEFAULT '1'"

    好处:

    • 降低主从延时的风险
    • 可以限速、限资源,避免操作时MySQL负载过高

    建议:

    • 在业务低峰期做,将影响降到最低
    • 删除索引后再修改表结构,效率将大大提升

    安装步骤参考:

    https://cloud.tencent.com/developer/article/1524019

    https://www.percona.com/downloads/percona-toolkit/LATEST/

  • 相关阅读:
    设计模式六大原则
    .net Stream篇(七)
    .net Stream篇(六)
    .net Stream篇(五)
    .net Stream篇(四)
    Leetcode 18
    Leetcode 16
    Leetcode 15
    Leetcode 12
    Leetcode 9
  • 原文地址:https://www.cnblogs.com/zjfjava/p/12907997.html
Copyright © 2011-2022 走看看