mysql 如何给大表添加字段

MySQL运维 靠谱运维 258℃ 0评论

基本思路:

① 创建一个临时的新表,首先复制旧表的结构(包含索引)
create table new_table like old_table;
② 给新表加上新增的字段
③ 把旧表的数据复制过来
insert into new_table(filed1,filed2…) select filed1,filed2,… from old_table
④ 删除旧表,重命名新表的名字为旧表的名字
不过这里需要注意,执行第三步的时候,可能这个过程也需要时间,这个时候有新的数据进来,所以原来的表如果有字段记录了数据的写入时间就最好了,可以找到执行这一步操作之后的数据,并重复导入到新表,直到数据差异很小。不过还是会可能损失极少量的数据。
所以,如果表的数据特别大,同时又要保证数据完整,最好停机操作。

过程SQL:

  1. create table xx_order_bak like xx_order;
  2. alter table xx_order_bak add column `unit` int(10) DEFAULT 1;
  3. INSERT INTO xx_order_bak(`id`, `create_date`, `modify_date`, `address`, `amount_paid`)
  4. select * from xx_order;
  5. rename table xx_order to xx_order_bak1;
  6. rename table xx_order_bak to xx_order;

转载请注明:靠谱运维 » mysql 如何给大表添加字段

喜欢 (0)or分享 (0)
发表我的评论
取消评论

表情