mysql跨库查询解决方案

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 ;

  • 16
    点赞
  • 97
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
MySQL进行跨库分页查询时,由于数据分散在不同的库中,所以无法直接使用简单的SQL语句实现分页查询。需要采用一些特定的解决方案。 一种常见的解决方案是使用分布式数据库中间件,如MyCAT、ShardingSphere等。这些中间件提供了跨库分页查询的功能,可以将用户的分页请求转换为多个子查询,并在各个库中执行这些子查询,最后将结果合并返回给用户。这样,就能够实现跨库分页查询的需求。 另一种解决方案是采用分页缓存的方式。在分库分表的情况下,将分页查询结果缓存在内存中,可以提高查询性能。当用户发起分页查询请求时,先从缓存中获取数据,如果缓存中不存在,则需要查询多个库,获取所需数据,然后将查询结果合并返回给用户,并将结果缓存起来供下次查询使用。 需要注意的是,跨库分页查询可能会引入性能和一致性的问题。由于需要查询多个库,可能会增加查询的时间。同时,在分布式环境下,数据的一致性也需要特别关注。因此,在设计和实现跨库分页查询时,需要综合考虑性能和一致性的平衡。 综上所述,针对MySQL跨库分页查询,可以考虑使用分布式数据库中间件或分页缓存的解决方案,以满足大数据量的存储和查询需求。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [MySQL分库分表的分页查询解决方案](https://blog.csdn.net/weixin_30658827/article/details/113968084)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [MySQL 跨库分页/ 分表分页/ 跨库分页](https://blog.csdn.net/qq_31587111/article/details/122732313)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值