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

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

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

基本思路

第一步 复制远程的数据库到本机数据库

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一样的。再重复第二步的方法就可以了

你可能感兴趣的:(mysql)