一、 什么是federated引擎

mysql中的federated类似于oracle中的dblink。

federated是一个专门针对远程数据库的实现,一般情况下在本地数据库中建表会在数据库目录中生成相对应的表定义文件,并同时生成相对应的数据文件。

[图]

但是通过federated引擎创建的表只是在本地有表定义文件数据文件则在远程数据库中

[图]

针对federated存储引擎表的查询会被发送到远程数据库的表上执行,本地是不存储任何数据的。

1. 本地的表结构必须与远程的完全一致。本地可以比远端数据库的字段少,但是不能多。因为多的话字段就没有地方存储了,还记得么,federated只在本地存储了表结构。

2. 远程的数据库必须是mysql。

3. 不支持事务。

4. 不支持表结构修改,远端表结构变了本地不知道(并不会主动通知本地,不理解,搞个监听器很难吗),一旦远端修改了表结构就gg了。

5. 创建时远程数据服务器必须已经存在此表。

6. 一个federated表指向另一个federated表是有可能的,但是要避免死循环。

7. 不使用查询缓存。

8. 远程服务器gg,federated表gg。

二、 如何使用

1. 开启federated引擎

mysql默认是没有打开federated存储引擎的。

如果报这种错误,就可能是没有打开federated存储引擎:

使用 show engines 命令查看当前的引擎支持状况:

在mysql的配置文件中 :

这个只是一个引用,去在圈中的文件中:

在[mysqld]节点下添加一行 federated:

重启mysql即可:

再连接到myql, show engines

2. 创建federated表

先在A服务器创建一张表:

-- A服务器
drop database if exists foo_db ;
create database foo_db default charset utf8 ;
use foo_db;
drop table if exists t_foo_table ;
create table t_foo_table(
id int primary key auto_increment ,
username varchar(20) not null ,
passwd varchar(20) not null
)charset=utf8;

然后在B服务器创建另一张表,结构和之前创建的一模一样,不同的只是多了指定engine和connection:

-- B服务器
drop database if exists foo_db ;
create database foo_db default charset utf8 ;
use foo_db;
drop table if exists t_foo_table ;
create table t_foo_table(
id int primary key auto_increment ,
username varchar(20) not null ,
passwd varchar(20) not null
)charset=utf8 engine=federated connection="mysql://root:@10.26.200.134/foo_db/t_foo_table";

connection的格式:

mysql://username:passwd@hostname/db_name/table_name

在A服务器往表中插入一条数据:

insert into t_foo_table (username, passwd) values ("foo", "bar");

在B服务器查询:

同理在B服务器插入,在A服务器也能查得到,实际上是发送到A服务器执行,数据也是存储在A服务器上的。

3. 借助于federated表跨节点join

在B数据库再创建一个表:

-- 要连接的表
drop table if exists t_bar ;
create table t_bar(
id int primary key auto_increment ,
barbar varchar(20) not null default ""
)charset utf8;

插入数据:

insert into t_bar (id,barbar) values (1, "barbar");
insert into t_bar (id,barbar) values (2, "barbarbar");
insert into t_bar (id,barbar) values (3, "barbarbarbar");
insert into t_foo_table (username, passwd) values ("foofoooofoo", "barbaaaaarbar");
insert into t_foo_table (username, passwd) values ("foofooooofoo", "barbaaaarbar");
insert into t_foo_table (username, passwd) values ("foofooooofoo", "barbaaaarbar");

连表查询:

select * from t_bar as t1
join t_foo_table as t2 on t1.id=t2.id ;

查询结果:

OK,查询结果是从两台服务器的两个节点中取出来的。

三、 总结

使用federated有很大的局限性,而且总感觉很不靠谱的样子,讲道理的话应该使用中间件来实现的。

.

mysql跨节点join——federated引擎的更多相关文章

  1. mysql 跨库JOIN

    现有两台MYSQL数据库 一台是192.168.1.1 端口3306 上有数据库DB1 有表TABLE1一台是192.168.1.2 端口3307 上有数据库DB2 有表TABLE2192.168.1 ...

  2. MySQL FEDERATED引擎使用示例, 类似Oracle DBLINK

    原文地址:http://it.dataguru.cn/article-3352-1.html 摘要: 本地MySQL数据库要访问远程MySQL数据库的表中的数据, 必须通过FEDERATED存储引擎来 ...

  3. MySQL FEDERATED引擎使用示例, 类似Oracle DBLINK(转)

    1 引擎说明 本地MySQL数据库要访问远程MySQL数据库的表中的数据, 必须通过FEDERATED存储引擎来实现. 有点类似Oracle中的 数据库链接(DBLINK). 要允许这个存储引擎, 当 ...

  4. mysql跨服务器查询

    MySQL FEDERATED引擎使用示例, 类似Oracle DBLINK 摘要: 本地MySQL数据库要访问远程MySQL数据库的表中的数据, 必须通过FEDERATED存储引擎来实现. 有点类似 ...

  5. Mysql的跨服务器 关联查询--Federated引擎

    1.确认开启Federated引擎     查询FEDERATED功能是否开启: show ENGINES;       2.如果状态为NO则需修改my.ini文件,增加一行federated配置: ...

  6. MySQL - FEDERATED引擎实现跨服务器查询

    1. MySQL插件的安装与卸载 # 查看插件信息 mysql> show plugins; mysql> select plugin_name,plugin_status,plugin_ ...

  7. 【转】 mysql使用federated引擎实现远程访问数据库(跨网络同时操作两个数据库中的表)

    原文转自:http://www.2cto.com/database/201412/358397.html 问题: 这里假设我需要在IP1上的database1上访问IP2的database数据库内的t ...

  8. 利用MySQL之federated引擎实现DBLink功能

    有时候我们需要跨库join查询,但是配置多数据源成本又太高,Oracle提供了DBLink功能,MySQL中也有类似的实现:federated-engine. MySQL中使用federated引擎的 ...

  9. 2020-07-07:mysql如何实现跨库join查询?

    福哥答案2020-07-07: 1.同服务跨库.表名称带上库名.SELECT * FROM 数据库名称1.表名称 JOIN 数据库名称2.表名称 ON 数据库名称1.表名称.tid = 数据库名称2. ...

随机推荐

  1. java 基础 --Collection(Set)

    注意: 如果hashSet存储自定义对象,一定要重写hashCode()&&equals() 如果TreeSet存储自定义对象,让元素所属的类实现自然排序接口Comparable,并重 ...

  2. PHP中大括号用法

    Php中"{}"大括号的用法总结 在PHP中,大括号“{}”可以起到如下作用: 1.将多个独立语句合并为一个复合语句,例如 if ... else ...中经常如此使用 2.在变量 ...

  3. 第147天:web前端开发中的各种居中总结

    一.水平居中 方法① :行内元素 (父元素)text-align,(子元素)inline-block .parent{text-align: center;} .child{display: inli ...

  4. HDU4466_Triangle

    今天比赛做的一个题目,不过今天终于感受到了复旦题目有多坑了. 题目的意思是给你一段长为n个单位长度的直线,你可以选择任意连续单位长度的线段组成三角形,可以组成任意你可以组成任意多个三角形,且要求其中所 ...

  5. 【uoj#192】[UR #14]最强跳蚤 Hash

    题目描述 给定一棵 $n$ 个点的树,边有边权.求简单路径上的边的乘积为完全平方数的点对 $(x,y)\ ,\ x\ne y$ 的数目. 题解 Hash 一个数是完全平方数,当且仅当每个质因子出现次数 ...

  6. 【bzoj5173】[Jsoi2014]矩形并 扫描线+二维树状数组区间修改区间查询

    题目描述 JYY有N个平面坐标系中的矩形.每一个矩形的底边都平行于X轴,侧边平行于Y轴.第i个矩形的左下角坐标为(Xi,Yi),底边长为Ai,侧边长为Bi.现在JYY打算从这N个矩形中,随机选出两个不 ...

  7. 【bzoj1297】[SCOI2009]迷路 矩阵乘法

    题目描述 给出一个 $n$ 个点的有向图,每条边的权值都在 $[1,9]$ 之间.给出 $t$ ,求从 $1$ 到 $n$ ,经过路径边权和恰好为 $t$ 的方案数模2009. 输入 第一行包含两个整 ...

  8. TCP的拥塞控制 (三)

    1.   Multiple Packet Losses Fast Retransmit/Fast Recovery机制可以很好地处理单个packet丢失的问题,但当大量packet同时丢包时(一个RT ...

  9. Qt浅谈之总结(整理)

    Qt浅谈之总结(整理) 来源 http://blog.csdn.net/taiyang1987912/article/details/32713781 一.简介 QT的一些知识点总结,方便以后查阅. ...

  10. py2exe使用总结

    假如你用python写了个小程序,想给别人用或者给别人演示,但他电脑里没装python.wxpython等,这时候你可以试试py2exe,它是一个将python脚本转换成windows上的可执行程序( ...