网站首页 > 技术文章 正文
文中使用的MySQL版本为5.6。
之前我们有讲过在Oracle数据库中关于远程数据库的访问可以使用DBLinked来实现,那在MySQL中是否也存在类似的方式呢?
答案是肯定的,在MySQL中若想访问远程数据库可以通过开启Federated引擎+映射表实现。
1. 开启Federated引擎
首先了解一下如何开启Federated引擎。由于默认情况下Federated引擎是关闭的状态,那我们先看看当前数据库是否支持Federated引擎。
show engines;
如上图所示,当前数据库是支持Federated引擎的,但是没有开启。那么接下来通过修改配置文件来开启Federated引擎,如下图:
至于mysql.cnf文件的存储位置各个不同版本(指的是Docker镜像)的MySQL可能存放路径不一样,本机采用的是linux版的MySQL并且已经挂载到宿主机的指定目录,因此只需要修改宿主机指定位置上的mysql.cnf即可。
在添加完成后重启一下mysql服务,如下图:
重新登录一下然后看看是否已经启用,如下图:
2. 创建Federated Server连接
其实一般来说直接通过Federated的Connection就可以连接到远程的服务器对应的数据库和表,如下图:
(账号、密码和连接地址属于敏感信息都需要打码),这里最大的难点是远程数据库的密码中带有“@”关键字,因此创建的时候就会抛出下面错误:
Error Code: 1432. Can't create federated table. The data source connection string 'mysql://xxxhe:xxxhe!@#@192.168.xxx.xxx:xxxxxx/spot_paohe/spot_trad' is not in the correct format
为了解决这个问题,需要另建一个Federated Server来解决这种特殊字符的问题,以本例子为例需要使用下面的方式创建Federated Server,如下所示:
CREATE SERVER `spot_paohe_client`
FOREIGN DATA WRAPPER mysql
OPTIONS (
HOST '192.168.xxx.xxx',
PORT xxxxxx,
USER 'xxxhe',
PASSWORD 'xxxhe!@#',
DATABASE 'spot_paohe'
);
创建完成后可以通过以下命令进行连接,如下图:
这样就创建出来了对应的表了,如下图:
之后就可以在本地做完所有的数据清洗了。
猜你喜欢
- 2024-11-02 Navicat的使用教程,不怕你不努力,就怕你不学习,小白们的福音
- 2024-11-02 远程桌面 由于数据加密错误,这个会话将结束。请重新连接到远程
你 发表评论:
欢迎- 624℃几个Oracle空值处理函数 oracle处理null值的函数
- 616℃Oracle分析函数之Lag和Lead()使用
- 605℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 601℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 596℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 589℃【数据统计分析】详解Oracle分组函数之CUBE
- 577℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 565℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
-
- 国产化红利到底在哪?好多人都在瞎折腾
- Oracle 推出 Java 24,增强 AI 支持和后量子加密
- JAVA桥接模式适用场景,优缺点是什么你知道吗,这篇文章彻底讲透
- SpringBoot条件化配置(@Conditional)全面解析与实战指南
- Navicat Data Modeler使用教程十二:配置
- 软件测试|数据库的内连接,左连接,右链接分别是什么
- 每日学习“IT”是什么呢?(每日学习每日一词)
- SQLite:小众?其实它比你想象的更普及,连这个领域都有人用!
- 【推荐】一款实用且跨平台的数据库管理神器,支持Web浏览器
- Spring Batch中的JobRepository:批处理的“记忆大师”是如何工作
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端获取当前时间 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)