前言
偶然候必要进行跨服务器数据库查询,在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服务器
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |