内连接(inner join)与外连接(outer join)小结

article/2025/8/26 19:37:22

转载自 : 内连接(inner join)与外连接(outer join)小结_蝉 沐 风的博客-CSDN博客_inner join


mySQL包含两种联接,分别是内连接(inner join)和外连接(out join),但我们又同时听说过左连接,交叉连接等术语,本文旨在总结这些术语之间的关系。

1. 内连接

首先说明内连接的一个重要性质:内连接查询结果与表的顺序无关
(当然顺序可能会发生变化,但是对应关系绝对不会错乱!!!)

1.1 交叉连接(cross join)

当然,他还有其他的名字,比如:笛卡尔积,交叉积,还有最奇怪的名字“没有连接”(no join)
这里写图片描述 这里写图片描述
使用下列命令同时查询玩具表的toy列和男孩表的boy列,得到的结果就是交叉连接

SELECT t.toy,b.boy
FROM toys AS tCROSS JOINboys AS b;

其中,CROSS JOIN可以省略,简写为

SELECT t.toy,b.boy
FROM toys AS t,    boys AS b;

交叉连接回把第一张表的每个值与第二张表的每个值进行匹配,结果如下

这里写图片描述

 交叉连接是内连接的一种,你又可以把内连接看作是通过查询中的条件过滤掉某些结果数据行之后的交叉连接。

1.2 相等连接

我们假设每个男孩子都又一个玩具,表之间是一对一的关系,toy_id是外键,数据库表如下图

这里写图片描述这里写图片描述
 
我们想找到每个男孩儿拥有什么玩具,只需要将boys表中的toy_id和toys中的主键进行比对,就会得到结果 

SELECT boys.boy,toys.toy
FROM boysINNER JOINtoys
ON boys.toy_id=toys.toy_id;

这里写图片描述
1.3 不等连接

我们继续沿用1.2中的表结构,如果我们想找到每个男孩儿没有的玩具,这时候我们可以使用不等连接(说白了就是=换成<>,其他没有什么区别)

SELECT boys.boy,toys.toy
FROM boysINNER JOINtoys
ON boys.toy_id<>toys.toy_id
ORDER BY boys.boy;

这里写图片描述

1.4 自然连接

继续沿用1.2的表结构。。。。。
注意:自然连接只有在连接的列在两张表中的名称都相同时才会有用
其实,自然连接就是自动识别相同列的相等连接

SELECT boys.boy,toys.toy
FROM boysNATURAL JOINtoys
ORDER BY boys.boy;

得到的结果和1.2中的结果完全一样(顺序可能不同)

这里写图片描述
2. 外连接

首先说明外连接不同于内连接的一个性质:外连接查询与表的顺序有关

 

2.1 左外连接

LEFT OUTER JOIN(左外连接)接收左表的所有行,并用这些行与右表进行匹配
当左表与右表具有一对多的关系时,左外连接特别有用。我们仍然使用之前的表结构

这里写图片描述这里写图片描述

现在我们利用左外连接找出每个男孩拥有的玩具

SELECT b.boy,t.toy
FROM boys b
LEFT OUTER JOIN toys t
ON b.toy_id=t.toy_id;

LEFT OUTER JOIN左边的表boys我们称为左表,右边的toys称为右表,所以LEFT OUTER JOIN会取得左表boys的所有行和右表的toys的行进行匹配,结果如下

这里写图片描述
我们的查询结果和使用内连接时一样,难道说内连接和外连接没区别吗?怎么可能!!!接下来我们改变一下左表boys的表结构
 这里写图片描述这里写图片描述
我们向boys中新添加了一个Andy,把他的toy_id设置为6,注意,6在toys表中没有对应的玩具,接下来再次运行上述程序

 这里写图片描述

 我们发现居然出现了一个NULL,NULL的出现是要告诉我们右表toys中没有与左表boys中的Andy相匹配的行,也就是说

外连接一定会提供数据行,无论能否在另一个表中找出相匹配的行

接着做个实验,我们调换左表和右表的顺序

SELECT b.boy,t.toy
FROM toys t
LEFT OUTER JOIN boys b
ON b.toy_id=t.toy_id;

这里写图片描述

结论:出现NULL的列总是右表中的列

以下时左外连接的实际匹配过程

toys中的玩具hula hoop与boys中的Davey的记录比对,toys.toys_is=1,boys.toy_is=3
不匹配
toys中的玩具hula hoop与boys中的Bobby的记录比对,toys.toys_is=1,boys.toy_is=5
不匹配
toys中的玩具hula hoop与boys中的Beaver的记录比对,toys.toys_is=1,boys.toy_is=2
不匹配
toys中的玩具hula hoop与boys中的Richie的记录比对,toys.toys_is=1,boys.toy_is=1
成功匹配
…省略toy_id=2,3的匹配过程
toys中的玩具harmonica与boys中的Davey的记录比对,toys.toys_is=4,boys.toy_is=3
不匹配
toys中的玩具harmonica与boys中的Bobby的记录比对,toys.toys_is=4,boys.toy_is=5
不匹配
toys中的玩具harmonica与boys中的Beaver的记录比对,toys.toys_is=4,boys.toy_is=2
不匹配
toys中的玩具harmonica与boys中的Richie的记录比对,toys.toys_is=4,boys.toy_is=1
不匹配
右表查找完毕,没有匹配项,因此创建带有NULL值的行来对应harmonica
…省略baseball cards的匹配过程

2.2 右外连接

与左外连接完全相同,只不过是用右表来评价左表
此外:RIGHT OUTER JOIN左侧的表为右表!!!!!
这里只简单举一个例子,具体内容参考左外连接

SELECT b.boy,t.toy
FROM toys t
RIGHT OUTER JOIN boys b
ON b.toy_id=t.toy_id;

上述代码等同于

SELECT b.boy,t.toy
FROM boys b
LEFT OUTER JOIN toys t
ON b.toy_id=t.toy_id;

这两种写法都是都把toys作为右表,把boys作为左表

实验的表结构如下:
这里写图片描述这里写图片描述

结果:

这里写图片描述
在实际运用过程中,我们一般倾向于只使用一种,另一种简单了解就好。


http://chatgpt.dhexx.cn/article/6CCV7mGs.shtml

相关文章

np.dot、np.outer、np.matmul、np.multipy、np.inner、np.outer与np.cross几个函数之间的区别

np.dot、np.outer、np.matmul、np.multipy、np.inner、np.outer与np.cross几个函数之间的区别 一、数学上关于【内积】、【外积】的定义和计算1.1 数学上关于【内积/数量积】的定义和计算1.2 数学上关于【外积/叉积】的定义和计算 二、numpy中关于np.dot、np.outer、np.matmul、…

R语言 作图 outer()函数

outer()函数&#xff1a; outer(x,y,func):数组x与y的outer()函数会产生一个二维数组A&#xff0c;它的形状是 c(dim(x),dim(y)).A中对应元素A[x.index,y.index] func(x.index,y.index) outer(x,y):默认为两向量外积,即outer(x,y,x*y) x (x1,x2,x3),y (y1,y2,y3) #绘制曲…

[SPI]SPI协议详解

1.SPI协议简介 1.1.SPI协议概括 SPI&#xff0c;是英语Serial Peripheral interface的缩写&#xff0c;顾名思义就是串行外围设备接口。是Motorola首先在其MC68HCXX系列处理器上定义的。SPI接口主要应用在 EEPROM&#xff0c;FLASH&#xff0c;实时时钟&#xff0c;AD转换器&a…

【FPGA】SPI协议

1.SPI简介 SPI(Serial Perripheral Interface, 串行外围设备接口)是 Motorola 公司推出的一种同步串行接口技术。SPI 总线在物理上是通过接在外围设备微控制器(PICmicro) 上面的微处理控制单元 (MCU) 上叫作同步串行端口(Synchronous Serial Port) 的模块(Module)来实现的, 它…

SPI接口协议详解

一、SPI总线简介 SPI总线是摩托罗拉公司开发的一种高速、全双工、同步的通信总线&#xff0c;它通常由四条线组成&#xff1a; CS 片选信号SCLK 时钟信号MOSI 主机输出从机输入接口MISO 主机输入从机输出接口 SPI分为主机和从机&#xff0c;主机提供通信所需的时钟信号。 二…

SPI通信协议

串行外设接口&#xff08;SPIV3&#xff09;模块描述 1.1简介 SPI组件允许MCU与外设之间进行同步串行通信。软件可以轮询SPI状态标识或可以中断驱动的SPI操作。 1.1.1特性 SPIV3包含以下特性&#xff1a; 主模式与从模式准模式从选择输出带有CPU中断能力的模式故障标识位双…

SPI协议解析

SPI协议解析 概述接口SPI四种通信模式示例最后 概述 SPI是串行外设接口&#xff08;Serial Peripheral Interface&#xff09;的缩写&#xff0c;是一种高速的&#xff0c;全双工&#xff0c;同步的通信总线&#xff0c;并且在芯片的管脚上只占用四根线&#xff0c;节约了芯片…

SPI协议详解(工作特点、时序图)

文章目录 一、SPI总线介绍1.1.SPI信号列表1.2.SPI工作模式1.3.SPI特点——同步、串行、全双工、主从结构 二、SPI传输时序2.1.时钟极性CPOL与时钟相位CPHA2.2.时序图2.3.SPI配置信息2.4.SPI数据交换过程 一、SPI总线介绍 SPI&#xff0c;是英语Serial Peripheral interface的缩…

SPI 通讯协议

Cuitbasics 汽车ECU设计 2/2 当您将微控制器连接到传感器&#xff0c;显示器或其他模块时&#xff0c;您是否考虑过这两种设备是如何相互通信的&#xff1f;他们到底在说什么&#xff1f; 事实上电子设备之间的通信就像人类之间的交流&#xff0c;双方都需要说相同的语言。在电…

SPI学习(三):SPI协议波形

写在前面:上一小节介绍了SPI的基本工作原理与极性相位等知识&#xff0c;这一小结介绍波形 由于我实际用到的IP是ARM PrimeCell SSP(PL022)&#xff0c;所以会以这个IP为主&#xff0c;也会对比《SPI Block Guide V04.01》 一.PL022支持的三种帧格式介绍 一共有三种帧格式可…

SPI协议介绍

文章目录 1- SPI协议介绍2- SPI总线传输模式3- SPI总线数据交换3- SPI与I2C对比 1- SPI协议介绍 SPI&#xff08;Serial Peripheral Interface&#xff09;是一种高速全双工同步串行通信协议&#xff0c;它由一个主设备(Master)和一个或多个从设备(Slave)组成&#xff0c;其中…

【数字IC】深入浅出理解SPI协议

深入浅出理解SPI协议 一、什么是SPI协议二、什么是全双工通信协议三、SPI的信号线四、SPI的连接方式4.1 多NSS形式4.2 菊花链形式 五、SPI可配置变量5.1 时钟极性&#xff08;CPOL&#xff09;5.2 时钟相位&#xff08;CPHA&#xff09;5.3 CPOL和CPHA组合出四种情况5.4数据大小…

通信协议(二)——SPI协议

1、基础知识 1.1 概念 SPI&#xff08;Serial Peripheral Interface&#xff0c;串行外围设备接口&#xff09;&#xff0c;是Motorola公司提出的一种同步串行接口技术&#xff0c;是一种高速、全双工、同步通信总线&#xff0c;在芯片中只占用四根管脚用来控制及数据传输&am…

SPI协议代码

软件模拟SPI程序代码 文章目录 SPI协议简介●SPI接口介绍●SPI数据传输方向●SPI传输模式 通过两个单片机模拟SPI来加深理解※硬件连接方式✯SPI模式✯程序思路✯主机C代码波形✯从机C代码波形 概述&#xff1a;    通过两个MCU&#xff08;STM32F103&#xff09;来模拟SPI…

SPI协议讲解与总结

1.SPI通讯协议 SPI是串行外设接口&#xff08;Serial Peripheral Interface&#xff09;的缩写&#xff0c;是一种高速的&#xff0c;全双工&#xff0c;同步的通信总线 1.1 SPI引脚与工作过程 SPI的通信原理很简单&#xff0c;它以主从方式工作&#xff0c;这种模式通常有一…

【STM32】SPI协议通信详解

目录 一.SPI协议简介二.SPI物理层三.SPI协议层 1.通讯的起始和停止信号2.数据有效性3.时钟信号的相位和极性&#xff08;重点&#xff09; 四.SPI 特性及架构&#xff08;重点&#xff09; 1.通信引脚2.时钟控制逻辑3.数据控制逻辑&#xff08;非常重要&#xff09;4.全双工发…

FPGA实现的SPI协议(一)----SPI驱动

写在前面 SPI协议系列文章&#xff1a; FPGA实现的SPI协议&#xff08;一&#xff09;----SPI驱动 FPGA实现的SPI协议&#xff08;二&#xff09;----基于SPI接口的FLASH芯片M25P16的使用 1、什么是SPI协议 SPI&#xff08;Serial Peripheral Interface&#xff0c;串行外围设备…

SPI总线协议概述

一.概述 SPI(serial peripheral interface)是一种同步串行通信协议&#xff0c;由一个主设备和一个或多个从设备组成&#xff0c;主设备启动与从设备的同步通信&#xff0c;从而完成数据的交换。SPI是一种高速全双工同步通信总线&#xff0c;标准的SPI仅仅使用4个引脚&#xff…

SPI协议详解(总结)

关于SPI协议 1&#xff09;SPI是串行外设接口&#xff08;Serial Peripheral Interface&#xff09;的缩写&#xff1b; 2&#xff09;是一种高速的&#xff0c;全双工&#xff0c;同步的通信总线&#xff1b; 3&#xff09;在芯片的管脚上只占用四根线&#xff0c;节约了芯片的…

SPI通讯协议介绍

来到SPI通讯协议了。废话两句&#xff0c;“SPI很重要”&#xff0c;这是我在学校时候听那些单片机开发工程师说的。出来实习&#xff0c;到后来工作&#xff0c;确实如此&#xff0c;SPI的使用很常见&#xff0c;那么自然重要咯。 SPI(Serial peripheral interface)即串行外围…