返回顶部
首页 > 资讯 > 数据库 >利用MySQL之federated引擎实现DBLink功能
  • 549
分享到

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

利用MySQL之federated引擎实现DBLink功能 2014-12-02 03:12:35 549人浏览 猪猪侠
摘要

有时候我们需要跨库join查询,但是配置多数据源成本又太高,oracle提供了DBLink功能,Mysql中也有类似的实现:federated-engine。 mysql中使用federated引擎的表能够映射远程数据库的表,本

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

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

  1. mysql中使用federated引擎的表能够映射远程数据库的表,本地的这张表相当于远程数据库某表在本地的引用,在本地对表的操作能够实时的反应到远程表上,包括CRUD。
  2. 要实现首先需要开启本地库的federated引擎【远程数据库不需要任何配置】,使用SHOW ENGINES;语句查询本地库是否开启了federated-engine;如果没有开启,修改mysqlData目录下的my.ini配置文件,在文件末尾追加一行【federated】字符串,然后重启MySQL服务器就可以了。
    注意:linux环境,是在/etc/my.cnf文件末尾追加一行【federated】字符串。
  3. 前提是本地表必须与远程表的结构相同【最好直接拷贝远程表的建表SQL】,在创建本地表时指定远程表的链接与地址。
CREATE TABLE `t_button` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) COLLATE utf8_bin NOT NULL,
  PRIMARY KEY (`id`)
)  ENGINE = FEDERATED DEFAULT CONNECTioN = 'mysql://root:passWord@192.168.50.234:3306/yang_dev/t_remote_button' CHARSET = utf8-mb4;

只要本地表创建完成,就实现了两表的实时同步,此时就可以像操作本地表一样操作远程表。
另一种方式是在数据库级别的同步,适合更大粒度的同步。
由于远程连接中已经使用了@字符,所以用户名和密码中不能再有@字符。
注意
- 其实本地表只存了表结构,真实数据仍然在远程表,所有的数据操作最终都落实到了远程表,所以这样做可能会增加远程表的压力
- 远程表不能是视图。
- 本地可以对对远程表进行CRUD操作,为了安全起见,建议实践中给远程数据库和连接的表做单独的用户权限限制。

您可能感兴趣的文档:

--结束END--

本文标题: 利用MySQL之federated引擎实现DBLink功能

本文链接: https://lsjlt.com/news/4604.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作