承接国内外服务器租用托管、定制开发、网站代运营、网站seo优化托管接单、网站代更新,新老站点皆可!!咨询QQ:3787320601

详解mysql跨库查询解决方案

管理员 2023-07-05 09:29:08 互联网圈 7 ℃ 0 评论 4288字 收藏

1.第一种跨库查询,是在同一个mysql服务器下两个区别的数据库之间的联查,关系以下图

在这里插入图片描述

在同一个mysql服务器下,区别的两个数据直接加上库名就能够实现跨库查询了

select * from t_test1 t1, test2.t_test2 t2 where t1.id = t2.id

在这里插入图片描述

履行sql查询到一下结果

在这里插入图片描述

2.第二种跨库查询,是在两台区别服务器(物理服务器)上分别安装的mysql服务器,实现跨库查询,其实现原理类似一个虚拟映照,需要用到mysql的另外一个存储引擎Federated,FEDERATED存储引擎访问在远程数据库的表中的数据,而不是本地的表。

这个特性给某些开发利用带来了便利,你可以直接在本地构建一个federated表来连接远程数据表,配置好了以后本地表的数据可以直接跟远程数据表同步。实际上这个引擎里面是不真实寄存数据的,所需要的数据都是连接到其他MySQL服务器上获得。

mysql默许没有开启federated存储引擎,需要在配置文件里面开启;

#在[mysqld] 下 添加 federated 然后重启mysql服务就能够了
[mysqld]
federated

以下图:

在这里插入图片描述

#输入命令查看引擎开启状态
show engines;

可以看到,已开启了

在这里插入图片描述

然后便可在test1数据库上创建虚拟表了,将test2库上t_test2表映照到test1库上面

CREATE TABLE `t_test2` (
`id` int NOT NULL,
`name` varchar(255) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=FEDERATED DEFAULT CHARSET=utf8mb3 COMMENT=’远程测试表t_test2′ CONNECTION=’mysql://root:123456@127.0.0.1:3306/test2/t_test2′ ;
/**

CONNECTION=’mysql://root:123456$@127.0.0.1:3306/test2/t_test2′ 这个配置是关键
root:代表远程数据库的用户
123456:代表远程数据的密码
127.0.0.1:代表远程数据库的ip地址,域名也能够
test2:代表远程数据库的数据库名称
t_test2:代表远程数据库中的哪一张表
**/

履行sql语句

在这里插入图片描述

可以看到创建了一张t_test2的表,这张表其实不存在只是一个远程的映照而已

在这里插入图片描述

可以看到使用FEDERATED引擎

在这里插入图片描述

表创建完成后就能够写sql了

select * from t_test1 t1, t_test2 t2 where t1.id = t2.id

可以看到履行结果

在这里插入图片描述

federated使用注意事项:

1.本地创建的表名一定要在远程服务器存在,创建的字段也一定要是远程表中的字段,可以比远程表的字段少,但是不能多,本地存储引擎选择

2.对本地虚拟表的结构修改,其实不会修改远程表的结构 

3.truncate 命令,会清除远程表数据 

4.drop命令只会删除虚拟表,其实不会删除远程表

5.select count(*), select * from limit M, N 等语句履行效力非常低,数据量较大时存在很严重的问题,但是按主键或索引列查询,则很快,如以下查询就非常慢(假定 id   为主索引)

select id from db.tablea where id >100 limit 10 ;

文章来源:丸子建站

文章标题:详解mysql跨库查询解决方案

https://www.wanzijz.com/view/61799.html

X

截屏,微信识别二维码

微信号:weimawl

(点击微信号复制,添加好友)

打开微信