一:不同表是在同一个mysql实例,也就是在同一个mysql服务器,ip一样
student表在test数据库,class表在test2数据库,跨库查询就只需指定库名称就行
select stu.*,cl.* from test.student stu left join test2.class cl on stu.id=cl.sid
二:所查的表在不同的实例,在不同的mysql服务器
其实现原理类似一个虚拟映射,需要用到mysql的另一个存储引擎Federated,FEDERATED存储引擎访问在远程数据库的表中的数据,而不是本地的表。
这个特性给某些开发应用带来了便利,你可以直接在本地构建一个federated表来连接远程数据表,配置好了之后本地表的数据可以直接跟远程数据表同步。实际上这个引擎里面是不真实存放数据的,所需要的数据都是连接到其他MySQL服务器上获取。
mysql默认没有开启federated存储引擎,需要在配置文件里面开启;
1 2 3 |
|
show engines;
查看FEDERATED 是否开启
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:代表远程数据库中的哪一张表
**/
然后就可以执行连表查询了
federated使用注意事项:
1.本地创建的表名必须在远程服务器存在,创建的字段也必须是远程表中的字段,可以比远程表的字段少,但是不能多,本地存储引擎选择
2.对本地虚拟表的结构修改,并不会修改远程表的结构
3.truncate 命令,会清除远程表数据
4.drop命令只会删除虚拟表,并不会删除远程表
5.select count(*), select * from limit M, N 等语句执行效率非常低,数据量较大时存在很严重的问题,但是按主键或索引列查询,则很快,如以下查询就非常慢(假设 id 为主索引)
1 |
|
不同数据库在同一个实例做查询的话,可以推荐使用clickhouse做查询,将数据库的数据同步到clickhouse,就可以做数据看板连表查询使用了