MYSQL 链接远程的链接表(类似ORACLE的DBLINK)
远程表:
CREATE
TABLE IF NOTEXISTS `category`
( `id`
int(11) NOTNULLAUTO_INCREMENT, `category_id`
int(11) NOTNULL, `
name`
varchar(20) NOTNULL,
PRIMARY
KEY(`id`) )
ENGINE=MYSAIM
DEFAULTCHARSET=utf8;
本地建立链接表(映射10.10.10.133 app库的category表)的时候:
`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:[email protected]:3306/app/category'; 注:表的结构一模一样,就是引擎不同,看红字FEDERATED
具体配置方法如下:
1.查看是否安装了 federated 引擎
输入命令:show engines;
结果如下:
从中可以看出 federated 引擎已经开启.(默认未开启)
2.开启 federated 引擎
windows下在 my.ini 中(或者 my.cnf or my.conf or my.ini )找到 [mysqld] 加入 federated ,即可开启,如:
1.查看是否安装了 federated 引擎
输入命令:show engines;
结果如下:
从中可以看出 federated 引擎已经开启.(默认未开启)
2.开启 federated 引擎
windows下在 my.ini 中(或者 my.cnf or my.conf or my.ini )找到 [mysqld] 加入 federated ,即可开启,如:
[mysqld]
federated
重启mysql
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处理机的将来版本可能被消除.