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

article/2025/9/23 21:14:04

用两个表(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

表测试数据:



一、内连接

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


说明:组合两个表中的记录,返回关联字段相符的记录,也就是返回两个表的交集(阴影)部分。

二、左连接(左外连接)

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


说明:
left join 是left outer join的简写,它的全称是左外连接,是外连接中的一种。
左(外)连接,左表(a_table)的记录将会全部表示出来,而右表(b_table)只会显示符合搜索条件的记录。右表记录不足的地方均为NULL。

三、右连接(右外连接)

关键字: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;
执行结果:


说明:
right join是right outer join的简写,它的全称是右外连接,是外连接中的一种。
与左(外)连接相反,右(外)连接,左表(a_table)只会显示符合搜索条件的记录,而右表(b_table)的记录将会全部表示出来。左表记录不足的地方均为NULL。


四、全连接(全外连接)

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_rowinner_iter = iterator over tbl2 where col3 = outer_row.col3inner_row = inner_iter.nextwhile inner_rowoutput [ outer_row.col1, inner_row.col2]inner_row = inner_iter.nextendouter_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.next
while outer_rowinner_iter = iterator over tbl2 where col3 = outer_row.col3inner_row = inner_iter.nextif inner_rowwhile inner_rowoutput [ outer_row.col1, inner_row.col2]inner_row = inner_iter.nextendelseoutput [ outer_row.col1, null]endouter_row = outer_iter.next
end
说明:第五部分摘自《高性能MySQL 第三版》









http://chatgpt.dhexx.cn/article/3uXpUmXx.shtml

相关文章

使用Java生成二维码图片

下面我来分享两种生成二维码图片的方法。 第一种&#xff0c;填入你扫描二维码要跳转的网址直接生成二维码 第一步&#xff1a;导入相关的包 1 <dependency> 2 <groupId>com.google.zxing</groupId> 3 <artifactId>core</artifactId>…

java生成二维码工具

1&#xff0c;添加maven依赖 <!-- 生成二维码 --> <dependency><groupId>com.google.zxing</groupId><artifactId>javase</artifactId><version>3.4.1</version> </dependency> 2&#xff0c;微信支付宝图片 3&#x…

二维码是什么?java生成二维码

生成二维码的网站可用于测试&#xff1a;草料二维码 参考资料&#xff1a;二维码&#xff08;QR code&#xff09;基本结构及生成原理 二维码 &#xff08;2-dimensional bar code&#xff09;&#xff0c;是用某种特定的几何图形按一定规律在平面&#xff08;二维方向上&…

关于Java生成二维码(zxing)

使用zxing生成二维码 提示&#xff1a;需要自己添加执行zxing.jar包 操作:点击链接去下载zxing包。GitHub - zxing/zxing: ZXing ("Zebra Crossing") barcode scanning library for Java, Androidhttps://github.com/zxing/zxing/ 文章目录 前言一、zxing是什么&…

一步一步教你用 java 生成二维码

一步一步用java设计生成二维码 在物联网的时代&#xff0c;二维码是个很重要的东西了&#xff0c;现在无论什么东西都要搞个二维码标志&#xff0c;唯恐落伍&#xff0c;就差人没有用二维码识别了。也许有一天生分证或者户口本都会用二维码识别了。今天心血来潮&#xff0c;看见…

java生成二维码到文件,java生成二维码转成BASE64

java生成二维码到文件&#xff0c;java生成二维码转成BASE64 如题&#xff0c;利用java和第三方库&#xff0c;把指定的字符串生成二维码&#xff0c;并且把二维码保存成图片&#xff0c;转换成BASE64格式。 需要的jar文件&#xff1a; package com.xueyoucto.xueyou;import …

关于java生成二维码:QR Code

QR Code的生成和读取在两个文件&#xff1a; 生成&#xff1a;QRcode​​​​​qrcode encoder (cgi programs/libralies) , QRcode demo and document of how to createhttp://www.swetake.com/qrcode/index-e.html 读取&#xff1a; オープンソースのQRコードデコードライ…

JAVA-生成二维码图片

JAVA-生成二维码图片 有很多大佬写了&#xff0c;但是这种花里胡哨的活我最喜欢搞了 首先是依赖 官网地址&#xff1a;https://mvnrepository.com/artifact/com.google.zxing/core 一般找用的最多的&#xff0c;相对稳定&#xff0c;出问题了也肯定有大佬给出相对应的解决办…

原来Java生成二维码这么简单

文章目录 一、二维条码/二维码(2-dimensional bar code)的概念二、二维码的发展历史三、二维码的分类四、二维码的优缺点五、QR Code六、实例开发1、zxing生成二维码2、zxing进行二维码解析3、使用QR Code方式生成和解析二维码4、jquery-qrcode生成二维码 一、二维条码/二维码(…

java生成二维码,跳转到指定页面

一、介绍&#xff1a;生成二维码有很多种方法&#xff0c;比如微信公众号的生成二维码&#xff0c;但是这个二维码只能用微信扫描且会&#xff08;可以带参数&#xff09;自动跳转到微信的公众号页面&#xff0c;不支持跳转到其他网页。这里说的二维码是扫描&#xff08;微信、…

Java生成二维码(附工具类)

后台Java生成二维码 这里用到了谷歌的zxing包&#xff0c;maven依赖如下&#xff1a; <!-- 二维码依赖开始--><dependency><groupId>com.google.zxing</groupId><artifactId>core</artifactId><version>3.4.0</version></…

java生成二维码最简单方法

昨天接到了一个需求是通过jave服务端动态生成二维码&#xff0c;提供给前端调用&#xff0c;这里就介绍一下生成的过程。 我这里是一个springboot服务&#xff0c;springboot服务的jar包就不贴了 这里只粘贴二维码用到的依赖。 1、pom依赖&#xff0c;这里只用到了两个依赖 &…

java生成二维码(链接生成二维码)

Java二维码如何生成&#xff1f; awt。image。BufferedImage; import java。io。File; import javax。imageio。ImageIO; import com。swetake。util。Qrcode; public class QRCodeEncoderTest { public static void main(String[] args) throws Exception { Qrcode qrco…

JAVA生成二维码QRcode

JAVA生成二维码QRcode 1 : 配置集成1.1、配置maven1.2、配置文件1.3、logo文件 2 : 代码集成2.1、加载配置文件2.2、工具类2.3、测试类 3 : 测试结果3.1、生成二维码3.2、扫描结果3.3、资源 1 : 配置集成 1.1、配置maven pom文件中添加一下配置 <!-- QR code --> <…

Java实现生成二维码

前言&#xff1a; 目前所分享的技术栈为Javaweb之后学运用到的 有喜欢我分享的一些demo可以多多交流 生成二维码前提&#xff1a; 1.需要引入谷歌所推荐使用的jar包 2.此jar包名称叫做zxing&#xff0c;目前我还没找到能所下载的jar包 3.我这里有自己制作好的jar包可以云盘下…

使用Java生成二维码图片(亲测)

下面我来分享两种生成二维码图片的方法。 第一种&#xff0c;填入你扫描二维码要跳转的网址直接生成二维码 第一步&#xff1a;导入相关的包 1 <dependency> 2 <groupId>com.google.zxing</groupId> 3 <artifactId>core</artifactId>…

Java生成二维码的几种实现方式(基于Spring Boot)

本文将基于Spring Boot介绍两种生成二维码的实现方式&#xff0c;一种是基于Google开发工具包&#xff0c;另一种是基于Hutool来实现&#xff1b; 为了方便理解二维码的实际应用场景&#xff0c;举一些例子&#xff01; &#xff08;1&#xff09;进销存系统 想必大家都听说过…

RK3562 camera调试:MIPI资源和配置

这篇文章给大家介绍一下RK新的一颗RK3562的camera资源以及MIPI的配置。 目录 &#xff08;1&#xff09;RK3562 camera资源 ①RK3562 camera硬件框图 ②MIPI-CSI资源 ③VICAP资源 ④ISP资源 ⑤最多支持camera数量 &#xff08;2&#xff09;dts配置 &#xff08;3&…

电子设计入门——单片机最小系统

写在前面 本文以STM32F401RCT6为例&#xff0c;讲解单片机最小系统的设计方法&#xff0c;以及一些相关的原理。 上图所示即为单片机最小系统电路&#xff0c;我们将其分为三个部分&#xff0c;即电源电路、复位电路、时钟电路。在了解最小电路之前&#xff0c;我们先看看下面…

LCD/HDMI OUT调试经验(4)------点亮LCD

本文以最近在QCM6490平台调试的一块FT8719为例&#xff0c;详细介绍点亮一块LCD屏幕的完整过程。 点亮屏幕的操作主要分两部分&#xff1a;上电和配置MIPI参数。上电保证屏幕可以有正常的背光&#xff0c;而MIPI参数保证有合适的清晰度&#xff0c;分辨率和画面。 一、上电 拿…