MySQL远程复制把多个相同数据库表汇总到一个表

来源:互联网 发布:微杂志制作软件 编辑:程序博客网 时间:2024/05/22 17:12

读取多台服务器里的远程数据库的表,并汇总到一个数据库的表中

前提,对方数据库给了权限本机,本机可以远程登录到对方。
在这里用复制的方法。
基本思路是

  • 第一步 复制远程的数据库到本机数据库
mysqldump -h '被复制方的ip' -u对方用户名 -p对方密码 --opt --compress 数据库名 --skip-lock-tables | mysql -h localhost -u root -p主机密码 数据库名

ps:—这一步远程复制数据表到本机,但是同名数据表会被覆盖(-p主机密码中间不要有空格,即不要-p 主机密码,分别对应了账户和密码,把它们分开来写,如-u root -p 1234567就出错,合起来写就没错)

  • 第二步:把通过远程复制得到的表A,汇总到一个表B上,登录到mysql,使用下面的语句
mysql> insert B select * from A where not exists(select * from b where b.字段1=A.字段1 and b.字段2=A.字段2....); 把字段全补上(不要看漏了exists的s)
  • 第三步:我的数据库表汇总这一步就完成了,但是也可能出现另一种报错
    报错内容为两个表里有一小部分相同数据,一插入的时候就提示duplicate entry ‘XXX’ for key ‘primary’
    这种原因主要是用来汇总的表和远程复制过来的表的结构不一样,可能是主键的不一样,也可能是id重复导致的

    解决方法有
    方法一: 实际状况就是id auto_increment+primary key 无法插入,因此可在phpadmin下,把正表和副表的id 删除,重复2 的方法复制后再加上id
    方法二: 在本机上建一个用来汇总的表,表的结构和远程复制的一样.要真正的复制一个表。可以用下面的MySQL语句。

mysql> CREATE TABLE newtable LIKE oldtable;   mysql> INSERT INTO newtable SELECT * FROM oldtable;  

这样创建的newtable结构就是和oldtable一样的。再重复2的方法就可以了

  • 第四步: 完成
0 0