海哥 发表于 2024-12-7 08:25:10

MySQL实现跨服务器查询

前言

偶然候必要进行跨服务器数据库查询,在Oracle数据库中可以使用DBlink查询,但在MySQL中并没有DBlink。但是Mysql提供了另外一种方式,通过配置可以实现类似DBlink的功能。
一、开启FEDERATED

show engines;
https://i-blog.csdnimg.cn/direct/a3b7308bec694b239d82943141efbdc5.jpeg#pic_center
如果这里是NO,必要在配置文件中参加一行:federated
https://i-blog.csdnimg.cn/direct/e7d7b82c3890475ead112e78034302b6.jpeg#pic_center
改完重启服务,就变成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企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: MySQL实现跨服务器查询