外连接(OUTER JOIN)

article/2025/8/26 17:56:47

9.3.4  外连接(OUTER JOIN)

不管是内连接还是带WHERE子句的多表查询,都组合自多个表,并生成结果表。换句话说,如果任何一个源表中的行在另一个源表中没有匹配,DBMS将不把该行放在最后的结果表中。

而外连接告诉ODBC生成的结果表,不仅包含符合连接条件的行,而且还包括左表(左外连接时)、右表(右外连接时)或两个边接表(全外连接)中的所有数据行。

SQL的外连接共有3种类型:左外连接,关键字为LEFT OUTER JOIN、右外连接,关键字为RIGHT OUTER JOIN和全外连接,关键字为FULL OUTER JOIN。外连接的用法和内连接一样,只是将INNER JOIN关键字替换为相应的外连接关键字即可。

说明 使用外连接时,关键字OUTER是可选的,如可用LEFT JOIN替代LEFT OUTER JOIN。

下面分别介绍一下这几种外连接方式。

1.左外连接

左外连接,LEFT OUTER JOIN,告诉DBMS生成的结果表中,除了包括匹配行外,还包括JOIN关键字(FROM子句中)左边表的不匹配行。左外连接实际上可以表示为:

左外连接 = 内连接 + 左边表中失配的元组

其中,缺少的右边表中的属性值用NULL表示。图9.17给出了典型的左外连接示意图。

 
图9.17  左外连接

实例11  左连接STUDENT表和COURSE表

左连接STUDENT表和COURSE表,查询所有同学的学号、姓名、课程代码、课程名称、考试时间和成绩信息。实例代码:

SELECT         S.SNO,  SNAME, S.CNO, CNAME, CTEST, MARK
FROM        STUDENT  AS  S
LEFT OUTER JOIN   COURSE   AS  C
ON      S. CNO = C. CNO
ORDER BY    SNAME

运行结果如图9.18所示。

可见,最终得到的结果表中,除了包括两个表匹配的行(3~20行),还包括了左边表STUDENT中的不匹配行(1、2行),缺少的右边表,即COURSE表中的属性值用NULL表示。

技巧 在SQL Server中,可以在WHERE子句中使用“*=”符号实现左外连接。

 
图9.18  左连接STUDENT表和COURSE表的查询结果

在WHERE子句,使用“*=”符号实现左外连接实现上例,代码如下。

SELECT       S.SNO,  SNAME, S.CNO, CNAME, CTEST, MARK
FROM      STUDENT  AS  S, COURSE   AS  C
WHERE   S. CNO  *=  C. CNO
ORDER BY  SNAME

运行结果如图9.19所示。

 
图9.19  使用“*=”符号实现的左外连接

说明 在Oracle数据库系统中,只需将“*=”替换成“+=”可以得到相同的结果。

2.右外连接

右外连接(RIGHT OUTER JOIN)告诉DBMS生成的结果表中,除了包括匹配行外,还包括JOIN关键字(FROM子句中)右边表的不匹配行。右外连接实际上可以表示为:

右外连接 = 内连接 + 右边表中失配的元组

其中,缺少的左边表中的属性值用NULL表示。图9.20给出了典型的右外连接示意图。

 
图9.20  右外连接

实例12  右外连接STUDENT表和COURSE表

右外连接STUDENT表和COURSE表,查询所有同学的学号、姓名、课程代码、课程名称、考试时间和成绩信息。实例代码:

SELECT        S.SNO,  SNAME, S.CNO, CNAME, CTEST, MARK
FROM       STUDENT  AS  S
RIGHT OUTER JOIN  COURSE   AS  C
ON     S. CNO = C. CNO
ORDER BY   SNAME

运行结果如图9.21所示。

 
图9.21  右外连接STUDENT表和COURSE表的查询结果

可见,最终得到的结果表中,除了包括两个表匹配的行(3~20行),还包括了右边表COURSE表中的不匹配行(1、2行),缺少的左边表,即STUDENT表中的属性值用NULL表示。


技巧 在SQL Server数据库系统中,可以在WHERE子句中使用“=*”符号实现右外连接。

实例13  在WHERE子句中使用“=*”符号实现右外连接

在WHERE子句,使用“=*”符号实现实例12,代码如下。

SELECT        S.SNO,  SNAME, S.CNO, CNAME, CTEST, MARK
FROM       STUDENT  AS  S, COURSE   AS  C
WHERE    S. CNO  =*  C. CNO
ORDER BY   SNAME

运行结果如图9.22所示。

 
图9.22  使用“=*”符号实现的右外连接

3.全外连接

全外连接,FULL OUTER JOIN,告诉DBMS生成的结果表中,除了包括匹配行外,还包括JOIN关键字(FROM子句中)左边表和右边表的不匹配行。全外连接实际上可以表示为:

全外连接 = 内连接 + 左边表中失配的元组 + 右边表中失配的元组。

其中,缺少的左边表或者右边表中的属性值用NULL表示。图9.23给出了典型的全外连接示意图。

 
图9.23  全外连接

实例14  全外连接STUDENT表和COURSE表

全外连接STUDENT表和COURSE表,查询所有同学的学号、姓名、课程代码、课程名称、考试时间和成绩信息。实例代码:

SELECT        S.SNO,  SNAME, S.CNO, CNAME, CTEST, MARK
FROM       STUDENT  AS  S
FULL OUTER JOIN  COURSE   AS  C
ON     S. CNO = C. CNO
ORDER BY   SNAME

运行结果如图9.24所示。

 
图9.24  全外连接STUDENT表和COURSE表的查询结果

可见,最终得到的结果表中,除了包括两个表匹配的行(5~22行),还包括了右边表COURSE表中的不匹配行(1、2行),缺少的左边表,即STUDENT表中的属性值用NULL表示。以及左边表,STUDENT表中的不匹配行(3、4行),缺少的右边表,即COURSE表中的属性值用NULL表示。



http://chatgpt.dhexx.cn/article/Vgx1xqHP.shtml

相关文章

CROSS APPLY和OUTER APPLY的区别

CROSS APPLY和OUTER APPLY的区别 APPLY语法 在SQL中,有这样的一种查询方式,APPLY语法:微软添加了这个新的运算符用于关联一个带有函数的结果集,并把函数应用于表/视图中的每一个限定行中。这个运算符就是APPLY,APPLY的…

图解inner join和outer join的区别

一张图可以完美诠释区别:

lateral view 和 lateral view outer的区别

lateral view 为侧视图,一般用于行转列的处理中 通常会与explode 搭配使用 1、explode 可以拆分map or array 示例 select explode(split("1,2,3",,)) 结果 123 explode 不适用于多个字段 其中一个字段需要炸开的场景,此时需要搭配late…

left join和left outer join 有什么区别?这样解释通俗易懂

作为一名java程序员,求职面试时也会遇到mysql问题,有次我到一家软件面试,就遇到有一道笔试题是考核关于sql 的。 left join和left outer join 有什么区别? 关于left join我平时编写sql表关联时用得比较多,但对于left o…

Oracle 数据库中 FULL OUTER JOIN 的作用 ?

当需要同时显示两个表中所有记录时,FULL OUTER JOIN 就非常有用。 FULL OUTER JOIN 返回左表(Table A)和右表(Table B)的所有行,并且如果左表或右表中没有匹配的行,则使用 NULL 值填充缺失的部分…

四种连接类型:inner(内连接),left[outer](左外连接),right[outer](右外连接),full[outer](完全外连接)

在from子句中表示连接操作有四种:inner(内连接),left[outer](左外连接),right[outer](右外连接),full[outer](完全外连接)。 一、理论…

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

转载自 : 内连接(inner join)与外连接(outer join)小结_蝉 沐 风的博客-CSDN博客_inner join mySQL包含两种联接,分别是内连接(inner join)和外连接(out join),但我们又同时听说过左连接,交叉连接等术语,本文旨在总结这…

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()函数: outer(x,y,func):数组x与y的outer()函数会产生一个二维数组A,它的形状是 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,是英语Serial Peripheral interface的缩写,顾名思义就是串行外围设备接口。是Motorola首先在其MC68HCXX系列处理器上定义的。SPI接口主要应用在 EEPROM,FLASH,实时时钟,AD转换器&a…

【FPGA】SPI协议

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

SPI接口协议详解

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

SPI通信协议

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

SPI协议解析

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

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,是英语Serial Peripheral interface的缩…

SPI 通讯协议

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

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

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

SPI协议介绍

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

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

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

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

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