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


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

    1. MySQL中使用federated引擎的表能够映射远程数据库的表,在本地的使用federated的这张表相当于远程数据库某表在本地的引用,在本地对引用标的操作都能够实时的反映到远程表上,包括CRUD。

    2. 要实现首先需要开启本地库的federated引擎【远程数据库不需要任何附加配置】:

    • 使用SHOW ENGINES;语句查询本地库是否开启了federated-engine。
    • 如果没有开启,修改mysqlData目录下的my.ini配置文件,在文件末尾追加一行federated字符串,然后重启MySQL服务器就可以了。
      注意:在linux环境,是在/etc/my.cnf文件末尾追加一行federated字符串。
    1. 前提是本地表必须与远程表的结构相同【最好直接拷贝远程表的建表SQL】,在创建本地表时额外指定远程表的链接与地址,本地表的建表语句如下:
    CREATE TABLE `t_button` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `name` varchar(255) COLLATE utf8_bin NOT NULL,
      `weapon_id` int(11),
      PRIMARY KEY (`id`),
      KEY `i_wpn_id` (`weapon_id`) USING BTREE  #### 显式声明索引
    )  ENGINE = FEDERATED DEFAULT CONNECTION = 'mysql://root:password@192.168.50.234:3306/yang_dev/t_remote_button' CHARSET = utf8-mb4;
    

    只要本地表创建完成,就实现了两表的实时同步,此时就可以像操作本地表一样操作远程表。
    另一种方式是在数据库级别的同步,适合更大粒度的同步。

    注意

    1. 远程表不能是视图。
    2. 由于远程连接语法中已使用了特殊符号@,所以连接远程表的用户名和密码中皆不可包含@
    3. 其实本地表只存了表结构,真实数据仍然在远程表,所有的数据操作最终都落实到了远程表,所以这样做可能会增加远程表的压力
    4. 默认情况下在本地可以对远程表进行任何读写操作,为了安全起见,建议实践中给远程数据库和被连接的表做单独的用户权限隔离,如将remote用户在某几张表上的权限设为只读。
    5. 远程表如果有索引,本地表也必须显式声明,方能生效;若远程表的索引发生变更,本地表务必重新声明。
  • 相关阅读:
    PHP7.27: connect mysql 5.7 using new mysqli
    PHP: Browser, Operating System (OS), Device, and Language Detect
    PHP 在WIN10 下配置
    MySQL chartset
    學習Echart 2.2.7
    The open source JavaScript graphing library that powers Plotly
    D3.js 制作中国地图
    FastReport.Net
    CSS 3D transforms
    SparkCore的调优之开发调优
  • 原文地址:https://www.cnblogs.com/JaxYoun/p/12360567.html
Copyright © 2020-2023  润新知