在日常的开发中经常进行跨数据库进行查询数据。
同服务器下跨数据库进行查询在表前加上数据库名就可以查询到数据。
mysql跨服务器进行查询提供了FEDERATED引擎进行映射表,然后进行查询。
mysql数据库federated引擎是关闭的,首先需要先启用该引擎。mysql执行show engines命令查看引擎状态。
启用FEDERATED引擎
Windows下找到my.ini修改mysql配置。该文件是隐藏在ProgramData文件夹,在该地址:C:\ProgramData\MySQL\MySQL Server 5.7,可以通过%ProgramData%查找该隐藏文件件。
打开my.ini文件,在[mysqld] 下加上federated
重启mysql,再查看引擎
在mysql中创建远程服务器数据库中的需要映射的表,映射表名称可以随意命名,但是数据结构必要一样。
CREATE TABLE `hn_user` (
`id` varchar(32) NOT NULL,
`name` varchar(20) DEFAULT NULL,
`phone` varchar(11) DEFAULT NULL,
`idcard` varchar(18) DEFAULT NULL,
`update_time` bigint(13) DEFAULT NULL,
`add_time` bigint(13) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=FEDERATED CONNECTION='mysql://root:[email protected]:3306/db/user';
注意:ENGINE=FEDERATED,使用federated引擎,修改用户名,密码,地址,端口号,数据库,表
这样就可以将远程的user表数据实时映射到hn_user表中,实现mysql跨服务器查询数据。
密码包含特殊符号的处理:
解决方案有两个:
a.修改数据库密码
b. 采用创建server的方式
CREATE SERVER fedlk
FOREIGN DATA WRAPPER mysql
OPTIONS (USER 'user',PASSWORD 'password', HOST '...', PORT 3306, DATABASE 'db_river');
CREATE TABLE `myy_district` (
`id` int(20) NOT NULL COMMENT 'ID',
`state` varchar(2) CHARACTER SET utf8 DEFAULT '1' COMMENT '状态(0:此条数据失效,1:数据有效)',
PRIMARY KEY (`id`) USING BTREE
) ENGINE=FEDERATED DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='行政区' CONNECTION = 'fedlk/myy_district';
报错连接外部数据源时
把创建的server中host改为内网IP
————————————————
版权声明:本文为CSDN博主「banjw_129」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/banjw_129/article/details/83445849