mysql远程跨库联合查询的示例
作者:程宇寒 发布时间:2024-01-13 23:09:10
注意:myemployees库和shoppingCart库在同一台物理主机,如果不在同一台物理主机该怎么办呢?下面我会介绍到。
情况一2个库在同一台物理主机
联合查询(不同的2个库,myemployees库和shoppingCart库),这2个库在同一台物理主机上,都在我本机。
#联合查询(不同的2个库,myemployees库和shoppingCart库)
SELECT emp01.`employee_id`, emp01.`first_name` FROM myemployees.employees AS emp01 LIMIT 0, 5
UNION
SELECT emp02.`employee_id`, emp02.`first_name` FROM shoppingCart.`employees2` AS emp02;
#
SELECT emp01.`employee_id`, emp01.`first_name` FROM myemployees.employees AS emp01 LIMIT 0, 5
UNION ALL
SELECT emp02.`employee_id`, emp02.`first_name` FROM shoppingCart.`employees2` AS emp02;
情况二2个库不在同一台物理主机(即2个库分别在不同的物理主机)
为了演示效果,我这里使用我的虚拟机,我虚拟机里安装了Linux系统(centos),Linux系统中已经安装了MySql数据库,MySql数据库服务已经启动了,所有的环境已经全部弄好了。
我的Linux系统(centos)的ip是192.168.117.66。
我打算我本地的author表和远程的user表进行联合查询。
在linux中输入SHOW CREATE TABLE `user`;这句话得到的结果后,我们把
CREATE TABLE IF NOT EXISTS `user` (
`id` INT(11) DEFAULT NULL,
`name` VARCHAR(20) DEFAULT NULL
)
这段代码拷贝到我本地的数据库中,并且在末尾加上
ENGINE =FEDERATED CONNECTION='mysql://root:root@192.168.117.66:3306/testDB/user';这句话。
CREATE TABLE IF NOT EXISTS `user` (
`id` INT(11) DEFAULT NULL,
`name` VARCHAR(20) DEFAULT NULL
)ENGINE =FEDERATED CONNECTION='mysql://root:root@192.168.117.66:3306/testDB/user';
其实上面的那段语句,说白了,就是在我本地的数据库中建了一个远程数据库的连接的快捷方式(远程数据库的连接快捷方式),类似于什么呢?就类似于我们window操作系统中的桌面上的桌面快捷方式,我们双击一下桌面上的某个软件图标就能打开该软件,一样的道理嘛。
执行上面的语句即可。
对了,还有一点要注意:
你要查一下,你本地的mysql数据库的FEDERATED引擎有没有开启。
SHOW ENGINES;
如果FEDERATED是NO的话,说明没有开启,需要你去修改一下mysql数据库的配置文件。
修改本地mysql数据库的配置文件,在配置文件末尾加上federated,如下图:
如果你是windows系统的话,就修改my.ini文件,如果你用的是Linux系统的话,就修改my.cnf文件。
修改完配置文件后记得重启一下mysql的服务。
linux重启mysql服务,service mysqld restart。
windows重启mysql服务,在dos窗口中,输入net stop mysql服务名,然后再输入net start mysql服务名。
OK,全部搞定后,执行如下sql语句,即可看到跨库查询的查询结果。
#
SELECT id, aname FROM author
UNION
SELECT id, `name` FROM `user`;
SELECT * FROM author INNER JOIN `user`;
以上这种跨服务器跨库的查询,需要注意如下几点:
1.该跨库查询方式不支持事务,最好别使用事务。
2.不能修改表结构。
3.MySQL使用这种跨库查询方式,远程数据库目前仅支持MySQL,其他数据库不支持。
4.表结构必须和目标数据库表完全一致。
来源:https://blog.csdn.net/czh500/article/details/85345825
猜你喜欢
- tensorflow中tf.concat的axis的使用我一直理解的比较模糊,这次做个笔记理下自己的思路。import tensorflow
- 在Python中将字符串转换为集合使用 set() 类将字符串转换为集合,例如 my_set = set(my_str)。 set() 类将
- SQL Server 2008已经发布,我们可以看到它在各方面都有了显著的进步,这些让人侧目之处和失望之处都有可能极大地影响大型企业的采购意
- share一些python实现的code#!/usr/bin/env python#coding=utf-8import cv2img =
- 前言今天小编就带着大家来盘点一下数据抓取过程中这些主流的加密算法,它们有什么特征、加密的方式有哪些等等,知道了这些之后对于我们逆向破解这些加
- 在项目中,尤其是pc端的时候,我们在用户登录后会给前端返回一个标识,来判断用户是否登录,这个标识大多数都是用户的id  
- 突然想到了之前一直没留意的for循环中开goroutine的执行顺序问题,就找了段代码试了试,试了几次后发现几个有意思的地方,我暂时没有精力
- 本文为大家分享了Python3实现发送QQ邮件功能:html,供大家参考,具体内容如下之前已经成功发送了qq邮件。下面贴出html格式的qq
- Jupyter 是数据分析领域非常有名的开发环境,使用 Jupyter 写数据分析相关的代码会大大节约开发时间。设想这样一个场景:别的部门的
- 本文实例讲述了Python简单遍历字典及删除元素的方法。分享给大家供大家参考,具体如下:这种方式是一定有问题的:d = {'a
- 1. 介绍灰度切割:增强特定范围的对比度,突出图像 * 定范围的亮度(灰度级分层也叫灰度切割)实现灰度切割的方法有很多种,但基本的方法就两种,
- 关键路径计算是项目管理中关于进度管理的基本计算。 但是对于绝大多数同学来说, 关键路径计算都只是对一些简单情形的计算。今天,田老师根据以往的
- 1. 前言 本文介绍一个贝叶斯推断的pytho
- 今天没事回家写了个贴吧图片下载程序,工具用的是PyCharm,这个工具很实用,开始用的Eclipse,但是再使用类库或者其它方便并不实用,所
- 等了好久终于等到了V8,赶紧测测效果,放张官网的比对图官网链接https://github.com/ultralytics/ultralyt
- 前言地图定位这个功能大家都很熟悉吧,那微信小程序中要怎么实现地图定位呢,其实非常简单,没有大家想象中那么难,看完本篇文章,你也可以轻松实现这
- 准备在断网的和联网的机器安装pip,下载地址https://pypi.python.org/pypi/pip在联网的开发机器上安装好需要的包
- 本文实例讲述了js实现全国省市二级联动下拉选择菜单,分享给大家供大家参考。具体如下:效果图: 具体代码:<html>&
- 本文实例讲述了Java使用正则表达式截取重复出现的XML字符串功能。分享给大家供大家参考,具体如下:public static void m
- 本文实例讲述了python命令行参数解析OptionParser类的用法,分享给大家供大家参考。具体代码如下:from optparse i