Mysql关联查询的几种实现方式
在关系型数据库中,要进行多表查询,一般都会使用join连接。
join连接的本质其实类似与集合的交并操作,Mysql实现关联查询常见的几种方式如下;
本次测试表结构和数据:
- A表

- B表

1、左连接
概念说明:
左连接将左表A作为主表,右表B作为从表,左表作为外层循环,在右表中进行匹配,如果左表的记录在右表中没有匹配,则将该左表记录的右表项补空值;

语法&测试:
语法关键字为 LEFT JOIN,影响行数 4 行;

2、右连接
概念说明:
右连接将右表B作为主表,左表A作为从表,右表作为外层循环,在左表中进行匹配,如果右表的记录在左表中没有匹配,则将该右表记录的左表项补空值;

语法&测试:
语法关键字为 RIGHT JOIN,影响行数 4 行;

3、内连接
概念说明:
内连接将左表A和右表B对于条件相匹配的项进行组合,在结果中只会出现同时在左表和右表出现的项;

语法&测试:
语法关键字为 INNER JOIN 或 JOIN(JOIN等价于INNER JOIN),影响行数 3 行;

4、全连接
概念说明:
全外连接将左表A和右表B的所有记录进行匹配,如果在另外表项中不存在记录,则补空值;

语法&测试:
语法关键字为 UNION 用来组合左连接和右连接,影响行数 5 行;

5、左外连接
概念说明:
左外连接选择将左表A作为主表,右表B作为从表,循环遍历右表,查找与条件满足的项,如果在右表中没有匹配的项,则补空值,并且在结果集中选择只在左表中存在的数据;

语法&测试:
左表A独有的数据,影响行数 1 行;

6、右外连接
概念说明:
右外连接选择将右表作为主表,左表作为从表,循环遍历左表,查找与join条件满足的项,如果在左表中没有匹配的项,则补空值,并且在结果集中选择只在右表中存在的数据;

语法&测试:
右表B独有的数据,影响行数 1 行;

7、全外连接
概念说明:
全外连接将全连接中左右表相交的部分排除;

语法&测试:
左表A和右表B独有的数据,影响行数 2 行;

总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
windows 环境下 MySQL 8.0.13 免安装版配置教程
这篇文章主要介绍了windows 环境下 MySQL 8.0.13 免安装版配置教程,非常不错,具有一定的参考借鉴价值,需要的朋友参考下吧2018-12-12
mysql-connector-java与mysql版本的对应关系说明
这篇文章主要介绍了mysql-connector-java与mysql版本的对应关系说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2023-02-02
Windows 8.1下MySQL5.7 忘记root 密码的解决方法
最近学习碰到了一件挺令人尴尬的事情,我把MySQL的密码给忘记了,所以MySQL登录不进去。在网上找的解决方案都不靠谱,下面小编给大家分享Windows 8.1下MySQL5.7 忘记root 密码的解决方法,需要的朋友一起看看吧2017-07-07
MySQL大内存配置方案 如my-medium.ini、my-huge.ini等
这篇文章主要介绍了MySQL大内存配置方案 如my-medium.ini、my-huge.ini等,经测试确实不错,访问mysql速度快了很多2014-08-08
mysql 8.0.22 zip压缩包版(免安装)下载、安装配置步骤详解
这篇文章主要介绍了mysql 8.0.22 zip压缩包版(免安装)下载、安装配置步骤详解,本文分步骤通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2020-12-12
MySql 8.0.11-Winxp64(免安装版)配置教程
这篇文章主要介绍了MySql 8.0.11-Winxp64(免安装版)配置教程,非常不错,具有参考借鉴价值,需要的朋友参考下吧2018-05-05


最新评论