MySQL实现跨服务器查询
文章目录
- 前言
- 一、开启FEDERATED
- 二、建立链接
- 总结
前言
有时候需要进行跨服务器数据库查询,在Oracle数据库中可以使用DBlink查询,但在MySQL中并没有DBlink。但是Mysql提供了另外一种方式,通过配置可以实现类似DBlink的功能。
一、开启FEDERATED
show engines;
如果这里是NO,需要在配置文件[mysqld]中加入一行:federated
改完重启服务,就变成yes了。
二、建立链接
代码如下(示例):
CREATE SERVER DbLinkName
FOREIGN DATA WRAPPER mysql
OPTIONS (USER '目标数据库用户名',PASSWORD '密码', HOST 'xx.xx.xx.xx', PORT 端口, DATABASE '目标数据库');
CREATE TABLE `本地表` (
。。。。
字段、属性等。。。
)
ENGINE = FEDERATED DEFAULT CHARSET=utf8 CONNECTION = 'DbLinkName/目标表';
注意本地表名称和目标表名称必须一致。
总结
以上就是MySql链接远程数据库查询的方法,需要注意以下5点。
- 1、本地表结构必须与远程表完全一样
- 2、不支持事务
- 3、不支持表结构修改
- 4、删除本地表,远程表不会删除
- 5、远程服务器必须是一个MySQL服务器