• 售前

  • 售后

热门帖子
入门百科

mysql中的跨库关联查询方法

[复制链接]
极忘投 显示全部楼层 发表于 2021-10-25 19:53:29 |阅读模式 打印 上一主题 下一主题
业务场景:关联差别数据库中的表的查询
比如说,要关联的表是:呆板A上的数据库A中的表A && 呆板B上的数据库B中的表B。
这种情况下,想执行“select A.id,B.id from A left join B on ~~~;“那是不大概的,但业务需求不可变,数据库计划不可变,这就蛋疼了。。
办理方案:在呆板A上的数据库A中建一个表B。。。
这固然不是跟你开打趣啦,我们采取的是基于MySQL的federated引擎的建表方式。
建表语句示例:
  1. CREATE TABLE `table_name`(......) ENGINE =FEDERATED CONNECTION='mysql://[username]:[password]@[location]:[port]/[db-name]/[table-name]'
复制代码
条件条件:你的mysql得支持federated引擎(执行show engines;可以看到是否支持)。

如果有FEDERATED引擎,但Support是NO,说明你的mysql安装了这个引擎,但没启用,去my.cnf文件末添加一行 federated ,重启mysql即可;
如果压根就没有FEDERATED这一行,说明你的mysql就没有安装这个引擎,这就不能舒畅的玩耍了,最好去找你们家运维搞定吧,由于接下来的动作比较大,而且我也不知道怎么搞;
表明:通过FEDERATED引擎创建的表只是在当地有表界说文件,数据文件则存在于远程数据库中,通过这个引擎可以实现雷同Oracle 下DBLINK的远程数据访问功能。就是说,这种建表方式只会在数据库A中创建一个表B的表结构文件,表的索引、数据等文件照旧在呆板B上的数据库B中,相称于只是在数据库A中创建了表B的一个快捷方式。
于是,蛋就不疼了。。
必要注意的几点:
1. 当地的表结构必须与远程的完全一样。
2.远程数据库目前仅限MySQL
3.不支持事务
4.不支持表结构修改
其他网友的增补:
  1. CREATE TABLE IF NOT EXISTS `logintoken` (
  2. `id` int(11) NOT NULL AUTO_INCREMENT,
  3. `type` char(1) NOT NULL DEFAULT '0',
  4. `loginName` varchar(20) DEFAULT NULL,
  5. `token` varchar(2000) DEFAULT NULL,
  6. `tokenExpiredTime` timestamp NULL DEFAULT NULL,
  7. PRIMARY KEY (`id`)
  8. ) ENGINE =FEDERATED CONNECTION='mysql://root:root@192.168.5.102:3306/zysso/logintoken';
复制代码
使用远程5.12的 logintoken表,只必要自己开启FEDERATED 就可以了,5.12不消开启

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作