mysql远程数据库和本地数据进行表数据连接查询

使用场景,当前有两个数据库,一个是在本地,一个在远程服务器,想把远程数据库中 某一张表的数据库查询并放入到本地数据库表中。
做这个操作的前提是本地能连接远程数据库,这里是通过FEDERATED这个来实现
步骤主要两步:

  1. 先确定一下远程数据库和本地数据库中FEDERATED 模块是否可以使用
    输入命令SHOW ENGINES;查看,如果FEDERATED 这一栏的SupportYES表示可以使 用,如果为No则需要开启
    windows下编辑mysql配置文件my.ini 找到[mysqld] 标签在标签下加入federated,重 启 mysql服务器再查看是否开启
    Linux下编辑mysql配置文件my.cnf找到[mysqld]标签在标签下加入federated,重 启 mysql服务器再查看是否开启

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  1. 创建一个表并且表结构要和远程数据库中对应的表一致,语法在下面,CONNECTION 中的连接信息需要自己修改,如果密码有特殊符号可能会出现连接异常问题,表创建成 功后会在当前操作数据库中存在,使用查询可以看到表中的数据和远程数据库表中一致 ,这个时候就可以根据自己需求操作,比如我可以查询出两个表数据,不一致的就插入 到我本地表中,这个时候如果加个定时器,每天晚上执行一次也算是实现了数据库表的 数据同步
CREATE TABLE `t_sys_user_info_copy1` (
    `id` INT(11) NOT NULL AUTO_INCREMENT,
  `user_account` VARCHAR(20) NOT NULL COMMENT '用户账号',
  `user_picture_url` VARCHAR(500) DEFAULT NULL COMMENT '用户头像',
  `user_password` VARCHAR(255) NOT NULL DEFAULT '' COMMENT '用户密码123456加密值',
  `user_name` VARCHAR(50) NOT NULL COMMENT '用户姓名',
)ENGINE=FEDERATED CONNECTION='mysql://zz:123456@192.168.116.23:3306/test/user_info';#连接信息
#把表中数据加入到本地表中,这样就实现的两个数据库表中的数据同步
INSERT  INTO t_sys_user_info
SELECT * FROM t_sys_user_info_copy1 WHERE user_account NOT IN(
SELECT user_account FROM t_sys_user_info
);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值