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
- MySQL远程复制把多个相同数据库表汇总到一个表
- 把一个数据库中的表复制到另外一个数据库
- 把两个数据库中的两个表中,相同的字段的数据,从一个表复制到另一个表
- 把一个数据库的一张表复制到另一个数据库
- mysql 把数据库从一个服务器复制到另一个服务器
- mysql把1个表的字段内容复制到另外1个表的字段
- SQLite实现不同数据库的表内容复制--从一个数据库把表和内容复制到另一个数据库
- 把一个数据库中的表的内容复制到另一数据库中的表中
- Sql Server 2005/2008中把一个数据库中的表完整复制到另一个数据库
- 【mysql 数据迁移】 mysql 把数据库从一个服务器复制到另一个服务器
- SQL数据库中把一个表中的数据复制到另一个表中
- SQL数据库中把一个表中的数据复制到另一个表中
- SQL数据库中把一个表中的数据复制到另一个表中
- 把数据库表中的一个字段的一部分复制到另一个字段
- 从一个数据库把表和内容复制到另一…
- 把一个表某个字段内容复制到另一张表的某个字段。MYSQL
- mysql把一个表某个字段内容复制到另一张表的某个字段。
- MySQL数据库,从一个数据库中复制指定表到另一个数据库中
- 欢迎使用CSDN-markdown编辑器
- linux下查看和添加PATH环境变量
- Watch App简介
- UML九种图的分类
- 带你彻底理解RSA算法原理
- MySQL远程复制把多个相同数据库表汇总到一个表
- NetBeans GUI编程基本步骤
- Redhat Linux下开启telnet服务
- POJ2677.Tour
- c语言中地址加法与减法
- 【妄言之言】遇见
- strftime()函数,C语言时间格式化
- Lintcode 比较字符串
- 软件生命周期之软件计划阶段