CROSS APPLY和OUTER APPLY的区别

article/2025/8/26 18:00:13

CROSS APPLY和OUTER APPLY的区别

APPLY语法

在SQL中,有这样的一种查询方式,APPLY语法:微软添加了这个新的运算符用于关联一个带有函数的结果集,并把函数应用于表/视图中的每一个限定行中。这个运算符就是APPLY,APPLY的功能同联接很类似,APPLY运算分左右两个部分(可以理解为左右两表)既左表的每一行都和右表进行一次匹配,
APPLY语句操作分为两种格式:CROSS APPLY(内部联接)或OUTER APPLY(左外联接)。

APPLY的用处

当我们用select语句去调用一个表值函数或把表值表达式的每一个记录与表或者表值表达式相匹配,往往要很麻烦,不过APPLY就可以帮你解决这个问题。

实例

创建一个数据库

create database KU
go
use KU
go

创建一个两个数据表

--提供货物品牌表
CREATE TABLE website (id        int				primary key identity  NOT NULL ,		--主键品牌IDnames     varchar(20)       NOT NULL,								--品牌名称product   varchar(20)		NOT NULL,								--提供名称
);
-- go 为批处理
go
--提供货物数量表
CREATE TABLE Cont (id        int				primary key identity  NOT NULL ,		--主键IDWeID      int				references website(id)    NOT NULL,		--外键品牌IDcont      int			    NOT NULL,								--提供数量DateCont datetime   		NOT NULL,								--提供时间
);

在相应的表中添加数据

--添加安踏,耐克,李宁品牌商
insert into website(names,product) values('安踏','安踏轻量级跑鞋'),('耐克','耐克空军一号'),('李宁','李宁夏季板鞋')
-- go 为批处理
go
--添加品牌商提供数量信息
insert into Cont (WeID,cont,DateCont) values(1,100,GETDATE()),(1,300,'2022-07-07'),(1,50,'2022-06-10'),
(2,50,GETDATE()),(2,500,'2022-05-09')

查询一下表中的数据数据表中的数据
当我们想要查询每个品牌最近两次的提供货物的数量以及时间时
就可以用APPLY语法,
CROSS APPLY(内部联接)或OUTER APPLY(左外联接):

CROSS APPLY

语法的使用:
–SELECT 列名 FROM 表1名
–CROSS APPLY
–(
–select 列名(条件) from 表2 where 条件
–)

SELECT T1.id,T1.names,T2.cont,T2.DateCont FROM website AS T1
CROSS APPLY(select top 2 * from Cont as T where T1.id =T.WeID order by T.DateCont desc
) as T2

查询结果:

CROSS APPLY查询
可以看出查询结果就按照我们的意向出来了,不过我们在查询结果中,并没有看到’李宁‘品牌的供应数量,这个时候我们就可以使用OUTER APPLY了

OUTER APPLY

语法的使用:
–SELECT 列名 FROM 表1名
–OUTER APPLY
–(
–select 列名(条件) from 表2 where 条件
–)

SELECT T1.id,T1.names,T2.cont,T2.DateCont FROM website AS T1
OUTER APPLY(select top 2 * from Cont as T where T1.id =T.WeID order by T.DateCont desc
) as T2

查询结果:
OUTER APPLY查询结果
可以看出,’李宁‘品牌商的供应数量也出来了,但是显示并没有提供货物

CROSS APPLY和OUTER APPLY两者区别

CROSS APPLY 的意思是“交叉应用”,在查询时首先查询左表,然后右表的每一条记录跟左表的当前记录进行匹配。匹配成功则将左表与右表的记录合并为一条记录输出;匹配失败则抛弃左表与右表的记录。
OUTER APPLY 的意思是“外部应用”,与 CROSS APPLY 的原理一致,只是在匹配失败时,左表与右表也将合并为一条记录输出,不过右表的输出字段为 null。

好了
今天的博客就到此为止了,大家还有什么不懂得可以私信评论留言哦!


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

相关文章

图解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…

SPI协议代码

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