今天接到开发妹子的需求,导入指定月份的数据到测试服mysql指定的表中(表名称不一样)
首先看了下线上的表的整体大小
mysql> SELECT sum(DATA_LENGTH)+sum(INDEX_LENGTH) FROM information_schema.TABLES where TABLE_SCHEMA='库名' AND TABLE_NAME='表名';
+------------------------------------+
| sum(DATA_LENGTH)+sum(INDEX_LENGTH) |
+------------------------------------+
| 4196941824 |
+------------------------------------+
1 row in set (0.00 sec)
这这数据有点大啊4G多,幸好只是只是导入指定月份的数据
开干
依稀记得mysqldump 有个功能可以指定范围导出 Google之后果断导出
/usr/local/mysql/bin/mysqldump -h192.168.1.1 -uzxc -pzxc123 库名 表名 --where="uptime >= 1404144000 and uptime <= 1406822399" > /tmp/表名.sql
导出还是比较快的,数据只有200多M
之后再想如何导入呢,表名称不一样,最后在各种辅助下,决定用合并表的方法弄
a、先导入到数据库的对应库里面
b、然后在采用合并表的方法合并数据
insert into 目标表 select * from 来源表;
ok之后发现数据在增加,在导入数据ing 轻松愉快的解决了这个问题
mysql> SELECT sum(DATA_LENGTH)+sum(INDEX_LENGTH) FROM information_schema.TABLES where TABLE_SCHEMA='库名' AND TABLE_NAME='表名';
+------------------------------------+
| sum(DATA_LENGTH)+sum(INDEX_LENGTH) |
+------------------------------------+
| 177422336 |
+------------------------------------+
1 row in set (0.00 sec)
数据在增长中。。。
导入成功之后,
满心欢喜的查看了数据,
select * FROM 表名称 LIMIT 1,10;
发现列名既然顺序不一样对应的数据不一样,醉了,妹子说好了数据结构一样的呢
只能重来,清空之前导入的数据之后,在根据来源表的列名顺序,指定导入进来的列名顺序
insert into 目标表(列1,列2,列3。。。) select * from 来源表;
现在才终于搞定收工