MYSQL 链接远程的链接表(类似ORACLE的DBLINK)

本文介绍如何使用MySQL的Federated存储引擎来链接远程数据库表,并详细解释了配置步骤及注意事项。包括如何确保Federated引擎已启用,如何创建映射表以及Federated引擎的功能限制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

MYSQL 链接远程的链接表(类似ORACLE的DBLINK)


远程表:
CREATE TABLE IF NOTEXISTS `category`
(   `id` int(11) NOTNULLAUTO_INCREMENT,   `category_id` int(11) NOTNULL,   `namevarchar(20) NOTNULL,   PRIMARYKEY(`id`) )
ENGINE=MYSAIM DEFAULTCHARSET=utf8;
 

 

本地建立链接表(映射10.10.10.133 app库的category表)的时候:

CREATE TABLE IF NOT EXISTS `remotecategory` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `category_id` int(11) NOT NULL,
  `name` varchar(20) NOT NULL,
   PRIMARY KEY (`id`)
)ENGINE=FEDERATED DEFAULT CHARSET=utf8  
CONNECTION='mysql://user:passwod@10.10.10.133:3306/app/category'; 注:表的结构一模一样,就是引擎不同,看红字FEDERATED


 
具体配置方法如下:
  1.查看是否安装了federated引擎
  输入命令:show engines;
  结果如下:
  

 

  从中可以看出federated引擎已经开启.(默认未开启)
  2.开启federated引擎
  windows下在my.ini中(或者my.cnf or my.conf or my.ini)找到[mysqld] 加入federated,即可开启,如:
[mysqld] 
federated 

重启mysql
  linux中,需要编译时加入选项,再在my.ini中加入federated,方可开启.
3.本地mysql数据库需要开启federated引擎,所连接的远程mysql库不需要开启
4.在建本地的映射表之前,应先确认引擎是否已启动。若未启动,在开启引擎后需要重建此表。
 

3.FEDERATED支持及不支持的如下:  

·远程服务器必须是一个MySQL服务器. FEDERATED对其它数据库引擎的支持可能会在将来被添加.  

·FEDERATED表指向的远程表在通过FEDERATED表访问它之前必须存在.  

·一个FEDERATED表指向另一个FEDERATED表是可能的, 但是必须小心不要创建一个循环.  

·没有对事务的支持.  

·如果远程表已经改变, 对FEDERATED引擎而言是没有办法知道的. 这个的原因是因为这个表必须象数据文件一样工作,

除了数据库其它任何都不会被写入. 如果有任何对远程数据库的改变, 本地表中数据的完整性可能会被破坏.  

·FEDERATED存储引擎支持SELECT,INSERT,UPDATE,DELETE和索引. 它不支持ALTER TABLE,DROP TABLE或任何

其它的数据定义语言语句. 当前的实现不使用预先准备好的语句.  

·执行使用SELECT,INSERT,UPDATE和DELETE, 但不用HANDLER.  

·FEDERATED表不能对查询缓存不起作用.  

这些限制中的一些在FEDERATED处理机的将来版本可能被消除. 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值