文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

mysql之跨库关联查询问题怎么解决

2023-07-05 10:39

关注

这篇文章主要介绍了mysql之跨库关联查询问题怎么解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇mysql之跨库关联查询问题怎么解决文章都会有所收获,下面我们一起来看看吧。

1、解决方案

mysql是不支持跨库连接的,如果我们实在要连接的话可以用dblink方式

mysql之跨库关联查询问题怎么解决

解释:

dblink就是我们在创建表的时候连接到我们的远程库,然后我们本地新建的表数据就是映射远程的表的数据

当我们创建一个以FEDERATED为存储引擎的表时,服务器数据库目录只创建一个表定义文件

文件由表的名字开始,并有一个frm扩展名。

无其它文件被创建,因为实际的数据在一个远程数据库上。这不同于为本地表工作的存储引擎的方式。

如我现在本地要连接我的阿里云的sys_user表

mysql之跨库关联查询问题怎么解决

所以我需要在本地建一个相同字段的表,我取名叫sys_user_copy,并连接到远程库

mysql之跨库关联查询问题怎么解决

建好后,我本地sys_user_copy的表里面的数据是映射远程的表的数据

mysql之跨库关联查询问题怎么解决

所以我关联查询,可以直接关联我本地sys_user_copy表从而查出来。

mysql之跨库关联查询问题怎么解决

改了本地的数据,远程的表数据也会跟着变

mysql之跨库关联查询问题怎么解决

2、操作

1、开启FEDERATED引擎

show engines

mysql之跨库关联查询问题怎么解决

如果这里是NO,需要在配置文件[mysqld]中加入一行:federated

mysql之跨库关联查询问题怎么解决

改完重启服务,就变成yes了。

2、建表时加上连接

mysql之跨库关联查询问题怎么解决

CREATE TABLE (......) ENGINE =FEDERATED CONNECTION='mysql://username:password@hostname:port/database/tablename'

这样即可。

3、缺点

本地表结构必须与远程表完全一样

不支持事务

不支持表结构修改

删除本地表,远程表不会删除5、远程服务器必须是一个MySQL服务器

关于“mysql之跨库关联查询问题怎么解决”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“mysql之跨库关联查询问题怎么解决”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯