同服务器下跨数据库进行查询在表前加上数据库名就可以查询到数据。
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中创建远程服务器数据库中的需要映射的表,映射表名称可以随意命名,但是数据结构必要一样。
点击(此处)折叠或打开
-
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:123456@192.168.1.8:3306/db/user'
点击(此处)折叠或打开
-
mysql> select * from test1;
- ERROR 1430 (HY000): : 0 :