图解MySQL 内连接、外连接、左连接、右连接、全连接……太多了

图解MySQL 内连接、外连接、左连接、右连接、全连接……太多了用两个表(a_table、b_table),关联字段a_table.a_id和b_table.b_id来演示一下MySQL的内连接、外连接(左(外)连接、右(外)连接、全(外)连接)。MySQL版本:Serverversion:5.6.31MySQLCommunityServer(GPL)数据库表:a_table、b_table主题:内连接、左连接(左外连

大家好,又见面了,我是你们的朋友全栈君。

用两个表(a_table、b_table),关联字段a_table.a_id和b_table.b_id来演示一下MySQL的内连接、外连接( 左(外)连接、右(外)连接、全(外)连接)。

MySQL版本:Server version: 5.6.31 MySQL Community Server (GPL)

数据库表:a_table、b_table

主题:内连接、左连接(左外连接)、右连接(右外连接)、全连接(全外连接)

前提

建表语句:

CREATE TABLE `a_table` (
  `a_id` int(11) DEFAULT NULL,
  `a_name` varchar(10) DEFAULT NULL,
  `a_part` varchar(10) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8
CREATE TABLE `b_table` (
  `b_id` int(11) DEFAULT NULL,
  `b_name` varchar(10) DEFAULT NULL,
  `b_part` varchar(10) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8

表测试数据:

图解MySQL 内连接、外连接、左连接、右连接、全连接……太多了

一、内连接

关键字:inner join on

语句:select * from a_table a
inner join b_table b
on a.a_id = b.b_id;
执行结果:
图解MySQL 内连接、外连接、左连接、右连接、全连接……太多了


说明:组合两个表中的记录,返回关联字段相符的记录,也就是返回两个表的交集(阴影)部分。
图解MySQL 内连接、外连接、左连接、右连接、全连接……太多了

二、左连接(左外连接)

关键字:left join on / left outer join on
语句:select * from a_table a
left join b_table b
on a.a_id = b.b_id;
执行结果:

图解MySQL 内连接、外连接、左连接、右连接、全连接……太多了


说明:
left join 是left outer join的简写,它的全称是左外连接,是外连接中的一种。

左(外)连接,左表(a_table)的记录将会全部表示出来,而右表(b_table)只会显示符合搜索条件的记录。右表记录不足的地方均为NULL。

图解MySQL 内连接、外连接、左连接、右连接、全连接……太多了

三、右连接(右外连接)

关键字:right join on / right outer join on
语句:select * from a_table a 
right outer join b_table b 
on a.a_id = b.b_id;
执行结果:

图解MySQL 内连接、外连接、左连接、右连接、全连接……太多了

说明:
right join是right outer join的简写,它的全称是右外连接,是外连接中的一种。

与左(外)连接相反,右(外)连接,左表(a_table)只会显示符合搜索条件的记录,而右表(b_table)的记录将会全部表示出来。左表记录不足的地方均为NULL。


图解MySQL 内连接、外连接、左连接、右连接、全连接……太多了

四、全连接(全外连接)

MySQL目前不支持此种方式,可以用其他方式替代解决。

五、补充,MySQL如何执行关联查询

MySQL认为任何一个查询都是一次“关联”,并不仅仅是一个查询需要到两个表匹配才叫关联,所以在MySQL中,每一个查询,每一个片段(包括子查询,甚至基于单表查询)都可以是一次关联。
当前MySQL关联执行的策略很简单:MySQL对任何关联都执行嵌套循环关联操作,即MySQL先在一个表中循环取出单条数据,然后在嵌套循环到下一个表中寻找匹配的行,依次下去,直到找到所有表中匹配的行为止。然后根据各个表匹配的行,返回查询中需要的各个列。请看下面的例子中的简单的查询:

查询语句:select tbl1.col1, tbl2.col2 from tbl1
inner join tbl2 using(col3) where tbl1.col1 in (5, 6);
假设MySQL按照查询中的表顺序进行关联操作,我们则可以用下面的伪代码表示MySQL将如何完成这个查询:
outer_iter = iterator over tbl1 where col1 in (5, 6)
outer_row = outer_iter.next
while outer_row
    inner_iter = iterator over tbl2 where col3 = outer_row.col3
    inner_row = inner_iter.next
    while inner_row
        output [ outer_row.col1, inner_row.col2]
        inner_row = inner_iter.next
    end
    outer_row = outer_iter.next
end

上面的执行计划对于单表查询和多表关联查询都适用,如果是一个单表查询,那么只需要上面外层的基本操作。对于外连接,上面的执行过程仍然适用。例如,我们将上面的查询语句修改如下:

select tbl1.col1, tbl2.col2 from tbl1
left outer join tbl2 using(col3) where tbl1.col1 in (5, 6);

那么,对应的伪代码如下:
outer_iter = iterator over tbl1 where col1 in (5, 6)outer_row = outer_iter.nextwhile outer_row    inner_iter = iterator over tbl2 where col3 = outer_row.col3    inner_row = inner_iter.next    if inner_row        while inner_row            output [ outer_row.col1, inner_row.col2]            inner_row = inner_iter.next        end    else        output [ outer_row.col1, null]    end        outer_row = outer_iter.nextend

说明:第五部分摘自《高性能MySQL 第三版》






版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/130224.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月14日 下午6:16
下一篇 2022年6月14日 下午6:16


相关推荐

  • 主题模型 LDA 入门(附 Python 代码)

    主题模型 LDA 入门(附 Python 代码)一 主题模型在文本挖掘领域 大量的数据都是非结构化的 很难从信息中直接获取相关和期望的信息 一种文本挖掘的方法 主题模型 TopicModel 能够识别在文档里的主题 并且挖掘语料里隐藏信息 并且在主题聚合 从非结构化文本中提取信息 特征选择等场景有广泛的用途 主题可以被定义为 语料库中具有相同词境的词的集合模式 比如说 主题模型可以将 健康 医生 病人 医院

    2026年3月16日
    2
  • pycharm看不到运行结果_pycharm系统找不到路径

    pycharm看不到运行结果_pycharm系统找不到路径一、起因不知道什么原因,好像是在下载安装了Java8.jdk后吧,浏览器的下载文件夹似乎被洗劫了一下那两个不是幸存了,是重下回来了…二、问题出现这个图虽然不是我的,但问题类型是一样的截图来自另一位大佬的解决办法:​​​​​​pycharm无法运行?系统找不到指定的文件?解决办法及其中的一个小坑_unseven的博客-CSDN博客_pycharm运行找不到指定文件四、奇妙地解决右键开始窗口打开应用和功能,下滑找到程序和功能进一步找到python右…

    2022年8月27日
    9
  • maven本地有包却加载失败_maven configuration problem

    maven本地有包却加载失败_maven configuration problem[INFO]BUILDFAILURE[ERROR]Failedtoexecute[ERROR]Formoreinformationabouttheerrorsandpossiblesolutions,pleasereadthefollowingarticles:1、问题情形项目代码是从SVN上刚下载的。同事在启动项目时,程序卡在下图这个地方不…

    2026年1月20日
    8
  • 0x80070035找不到网络路径_0x80004005无法访问共享

    0x80070035找不到网络路径_0x80004005无法访问共享提示!!!企业workstation最好用原版本操作系统。不要用ghost版本。些类问题多见于ghost版本。1.以管理员权限运行cmd.重启电脑,再试试。本人亲测可行。第一次访问可能会有

    2022年8月4日
    9
  • 如何在excel2019指定的单元格中插入图片

    如何在excel2019指定的单元格中插入图片最近,要完成一些论文的调研及整理工作,针对各个论文中提到的方法,系统模型等。原想在单元格中插入图片,发现单元格右键插入,压根就没插入图片这一项功能,如图所示故在菜单栏中,找到插入-》图片-》此设备,插入完成后,图片能在整个界面上移动。完全不是我想要的结果。问题解决办法如下:1、选中一个想要放入的单元格,尽量拉的大一点。2、把已插入的图拖到这个单元格内,大致调整一下大小,使其和单元格大小差不多。3、选中图片右键“大小和属性”。4、作如图设置,将属性选为“随单元格改变位置和大

    2025年6月29日
    4
  • C语言结构体指针_C语言函数返回结构体指针

    C语言结构体指针_C语言函数返回结构体指针文章目录结构体概述结构体指针结构体概述问题定义:有时需要将不同类型的数据组合成一个有机的整体,以便于使用,就类似于sql中的存储一样,随着语言层次的增高封装性是越来越大的。如:intnum;charname[20];charsex;intage;charaddr[30];定义结构的一般形式为:struct结构名{成员列表};成员列表由若干个成员构成,每个成员…

    2025年8月14日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号