SQL Server中CROSS APPLY连接操作

在 SQL Server 中,CROSS APPLY 是一个连接操作,它类似于 INNER JOIN,但有一些关键差异,特别是在处理表值函数(TVF)、行集函数或子查询时。CROSS APPLY 返回对于外部查询中的每一行,在内部查询或函数中都存在的行。但是,如果内部查询或函数对于外部查询的某行没有返回任何行,则该外部查询的行不会出现在结果集中。

以下是一些关键点,用于理解 CROSS APPLY:

  • 与 INNER JOIN 的比较:虽然 CROSS APPLY 在某些情况下可能产生与 INNER JOIN 相同的结果,但它们在处理一对多关系时有所不同。特别是当内部查询或函数返回多行时,CROSS APPLY 会为外部查询的每一行与内部查询或函数的每一行组合生成结果。
  • 与子查询的比较:与在 SELECT 语句中使用的子查询不同,CROSS APPLY 中的子查询或函数可以引用外部查询的列,就像它们在 JOIN 条件中一样。
  • 表值函数:CROSS APPLY 经常与表值函数一起使用,特别是当这些函数返回基于外部查询行值的动态结果集时。
  • 性能:在某些情况下,CROSS APPLY 可能会比使用其他连接类型(如 INNER JOIN)的查询更快,因为它可以更早地过滤掉不满足条件的行。但是,性能总是取决于具体的查询和数据分布。

假设我们有两个表:T_Product 和 T_Product_imgs。每个产品可能有多个上传的图片,但我们想为每个产品选择其最新图片。这可以通过使用 CROSS APPLY 和一个子查询来实现,该子查询返回每个产品的最新图片。

CREATE TABLE T_Product
(ID BIGINT IDENTITY(1,1) CONSTRAINT PK_ProductID PRIMARY KEY,Title NVARCHAR(64) NOT NULL CONSTRAINT DF_ProductTitle DEFAULT N'',Tag NVARCHAR(64) NOT NULL CONSTRAINT DF_ProductTag DEFAULT N'',Price DECIMAL(18,6) NOT NULL,CreateUser NVARCHAR(32) NOT NULL,CreateDate DATETIME DEFAULT GETDATE()
)CREATE TABLE T_Product_imgs
(ID BIGINT IDENTITY(1,1) CONSTRAINT PK_Product_imgsID PRIMARY KEY,Pro_id BIGINT NOT NULL,imgName NVARCHAR(64),CreateUser NVARCHAR(32) NOT NULL,CreateDate DATETIME DEFAULT GETDATE()
)
ALTER TABLE T_Product_imgs ADD CONSTRAINT FK_Product_imgs_ID FOREIGN KEY (Pro_id) REFERENCES T_Product (id) INSERT INTO T_Product (Title,Tag,Price,CreateUser,CreateDate) VALUES(N'雷霆打码机',N'打码',900000.89,N'DBA卢飞虎','2020-08-08 23:20:56')
INSERT INTO T_Product (Title,Tag,Price,CreateUser,CreateDate) VALUES(N'大族钻机',N'钻孔',1050000.66,N'DBA卢飞虎','2020-09-01 23:20:56')
INSERT INTO T_Product (Title,Tag,Price,CreateUser,CreateDate) VALUES(N'雪龙锣机',N'锣板',530000.76,N'DBA毛一飞',GETDATE()-30)INSERT INTO T_Product_imgs (Pro_id,imgName,CreateUser,CreateDate) VALUES(1,'XL-20200801161136.jpg',N'DBA-JAVA','2020-08-01 23:20:56')
INSERT INTO T_Product_imgs (Pro_id,imgName,CreateUser,CreateDate) VALUES(2,'LT-20200906162236.jpg',N'DBA卢飞虎','2020-09-06 13:20:26')
INSERT INTO T_Product_imgs (Pro_id,imgName,CreateUser,CreateDate) VALUES(3,'DC-20210808163336.jpg',N'DBA卢飞虎','2021-08-08 23:20:56')
INSERT INTO T_Product_imgs (Pro_id,imgName,CreateUser,CreateDate) VALUES(3,'DC-20211005163336.jpg',N'DBA卢飞虎','2021-10-05 22:20:56')
INSERT INTO T_Product_imgs (Pro_id,imgName,CreateUser,CreateDate) VALUES(2,'LT-20210609162236.jpg',N'Oracle','2021-06-09 20:20:56')
INSERT INTO T_Product_imgs (Pro_id,imgName,CreateUser,CreateDate) VALUES(1,'XL-20210808161136.jpg',N'JAVA','2021-08-08 23:20:56')
INSERT INTO T_Product_imgs (Pro_id,imgName,CreateUser,CreateDate) VALUES(1,'XL-20200608161136.jpg',N'MongDB','2020-06-08 23:20:56')SELECT * FROM T_ProductSELECT * FROM T_Product_imgs ORDER BY Pro_id,CreateDate DESC 

在这里插入图片描述

  • 使用INNER JOIN 和子查询使用ROW_NUMBER() OVER字句
SELECT a.id,a.title,a.Tag,a.Price,T.Pro_id,T.imgName
FROM T_Product AS aINNER JOIN  ( SELECT Pro_id,imgName,CreateDate,ROW_NUMBER() OVER(PARTITION BY Pro_id  ORDER BY CreateDate DESC) AS Rn FROM T_Product_imgs AS b ) AS T
ON a.id=T.Pro_id
WHERE T.Rn=1

在这里插入图片描述

  • CROSS APPLY 实现
    与子查询的比较:与在 SELECT 语句中使用的子查询不同,CROSS APPLY 中的子查询或函数可以引用外部查询的列
SELECT a.id,a.title,a.Tag,a.Price,T.Pro_id,T.imgName
FROM T_Product as aCROSS APPLY ( SELECT TOP 1 b.pro_id,b.imgName FROM T_Product_imgs AS b WHERE b.Pro_id=a.id ORDER BY b.CreateDate DESC) AS T

在这里插入图片描述
在上面的示例中,对于 T_Product 表中的每一行,子查询都会返回最新的产品图片 imgName (如果存在)。如果某个产品没有产品图片,则该产品的信息不会出现在结果集中。

INSERT INTO T_Product (Title,Tag,Price,CreateUser,CreateDate) VALUES(N'大板X99',N'主板',230670.00,N'DBA毛一飞',GETDATE()-30)

在这里插入图片描述
插入T_Product 表的ID=4数据,但没有在T_Product_imgs表中插入最新的产品图片 imgName

SELECT a.id,a.title,a.Tag,a.Price,T.Pro_id,T.imgName
FROM T_Product as aCROSS APPLY ( SELECT TOP 1 b.pro_id,b.imgName FROM T_Product_imgs AS b WHERE b.Pro_id=a.id ORDER BY b.CreateDate DESC) AS T

再次执行,发现T_Product 表的ID=4数据是没有出现在结果集中。充分验证如果内部查询或函数对于外部查询的某行没有返回任何行,则该外部查询的行不会出现在结果集中。
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/28637.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LabVIEW_OPC读取PLC数据

使用OPCDemo_西门子 Demo位置Program Files \ National Instruments \ Shared \ NI OPC Servers \ V5 \ Projects \ simdemo.opf. 使用共享变量的方式读取数据 1.Labview项目中新建IO服务器 选择OPC Client 选择NI OPC Server Labview会创建一个Lib库对OPC客户端进行管理。…

记录一个利用winhex进行图片隐写分离的

前提 是一次大比武里面的题目,属实给我开了眼,跟我之前掌握的关于隐写合并的操作都不一样。 它不是直接在文件里面进行输入文件隐写,叫你输入密码,或者更改颜色,或者偏移位置; 它不是单纯几个文件合并&a…

522. 最长特殊序列 II(Rust)

题目 给定字符串列表 strs ,返回其中 最长的特殊序列 的长度。如果最长特殊序列不存在,返回 -1 。 特殊序列 定义如下:该序列为某字符串 独有的子序列(即不能是其他字符串的子序列)。 s 的 子序列可以通过删去字符串…

基于SpringBoot校园食堂订餐管理系统

文章目录 系统运行图概要整体架构流程技术名词解释 系统运行图 概要 随着校园人口的增加和生活节奏的加快,校园食堂的订餐管理面临着诸多挑战,传统的人工点餐方式已经不能满足日益增长的需求和期望。因此,本论文旨在设计和实现一种基于Java的…

过滤器和拦截器的基本知识

过滤器和拦截器的基本知识 前提提要,由于过滤器和拦截器的相关函数是没有返回值的,所以我们像前端返回数据时需要使用到HttpServletResponse中的相关函数,且需要配合阿里巴巴的插件fastjson将返回信息转为json格式,或者使用gson转…

【CMU 15-445】Proj3 Query Execution

Query Execution 通关记录Task1 Access Method ExecutorsSeqScanInsertUpdateDeleteIndexScanOptimizing SeqScan to IndexScan Task2 Aggregation & Join ExecutorsAggregationNextedLoopJoin Task3 HashJoin Executor and OptimizationHashJoinOptimizing NestedLoopJoin…

vue分类

先看效果 再看代码 <category-tab v-model"params.area" name"地区" :list"areaList" /><category-tab v-model"params.type" name"类型" :list"typeList" /><category-tab v-model"params.…

如何让AI 帮你生成 git 提交信息

在协同开发的项目中&#xff0c;我们肯定避免不了使用git提交代码&#xff0c;所以经常会看到了一些描述不清的提交信息。当遇到种情况时&#xff0c;我们也不必为此责怪开发人员&#xff0c;因为我们确实很难记住你在 git 提交时刚刚做了什么。 Nutlope / aicommits 一个使用 …

编译原理:代替LR的MP:2.遇到的问题

用指针加速 MP是multi-pass&#xff0c;多遍分析法&#xff0c;它是从“先乘除后加减”中得来的灵感。在实践中&#xff0c;发现C语言优先级有15级&#xff0c;如果将源代码处理15遍&#xff0c;每一遍都从头开始找&#xff0c;势必很慢。所以&#xff0c;有了用指针加速的想法…

Attention机制到底是什么?

AI算法之一 的Attention机制到底是什么&#xff0c;你知道吗? 这里写目录标题 1. Attention 的本质2. Attention的3大优点3. Attention的原理3.Attention的类型3.1计算区域3.2 所用信息3.3 结构层次 4. 模型方面5. 相似度计算 1. Attention 的本质 Attention&#xff08;注意…

构建数字化校园,开启创新教育模式

在当今信息化时代&#xff0c;教育的转型升级已成为推动社会进步与发展的关键力量。构建数字化校园&#xff0c;不仅是对传统教育模式的革新&#xff0c;更是开启一场以技术赋能教育、创新驱动成长的教育革命。这一进程旨在通过深度融合信息技术与教育教学实践&#xff0c;重塑…

hive on spark 记录

环境&#xff1a; hadoop 2.7.2 spark-without-hadoop 2.4.6 hive 2.3.4 hive-site.xml <property><name>hive.execution.engine</name><value>spark</value> </property> <property><name>spark.yarn.jars</name>&l…

【代码随想录——动态规划——第三周】

1.目标和 这里设置背包的最大长度为2100即可&#xff0c;因为题目中有说数组之和小于1000.但考虑到我们需要实行jnums[i]所以保守起见我们设置的数应该稍大于2000即可&#xff0c;这里我们设置为2100。 1.1 我的解法&#xff08;粗糙了&#xff09; func findTargetSumWays(n…

BetterZip 5软件安装包下载

BetterZip是一款功能强大的Mac解/压缩软件&#xff0c;可以满足用户对文件压缩、解压、加密和保护等方面的需求。以下是关于BetterZip软件的主要功能、特点和使用方法的详细介绍&#xff0c;以及对其用户友好度、稳定性和安全性的评价。 安 装 包 获 取 地 址: BetterZip 5-安…

R语言 | 绘制带P值的差异柱状图

原文链接&#xff1a;R语言 | 绘制带P值的差异柱状图 本期教程 小杜的生信笔记&#xff0c;自2021年11月开始做的知识分享&#xff0c;主要内容是R语言绘图教程、转录组上游分析、转录组下游分析等内容。凡是在社群同学&#xff0c;可免费获得自2021年11月份至今全部教程&…

Vue55-TodoList案例-本地存储

一、TodoList案例-本地存储 此时&#xff0c;修改对象里面的属性&#xff0c;watch监视不到&#xff01; 需要深度监视&#xff0c;就不能用简写形式&#xff01; 二、jeecg-boot中的本地存储 jeecg-boot中&#xff0c;浏览器的本地存储&#xff0c;存储的是token&#xff01;…

Parallels Desktop 19 for mac破解版安装激活使用指南

Parallels Desktop 19 for Mac 乃是一款适配于 Mac 的虚拟化软件。它能让您在 Mac 计算机上同时运行多个操作系统。您可借此创建虚拟机&#xff0c;并于其中装设不同的操作系统&#xff0c;如 Windows、Linux 或 macOS。使用 Parallels Desktop 19 mac 版时&#xff0c;您可在 …

git 如何撤销已经 push 的 merge

今天在合并代码时, 发现自己失误把另外一个分支 B 的代码合并到了自己分支 C, 于是想到要撤销这次 merge 一般地, 如果我们想要撤销某次 commit 可以 git revert <commit-id>. 然而, 对于 merge 类型的 commit 不能直接 git revert <commit-id> 这里举个例子: 我…

最新编程语言排行榜,C++ 和 Go 成为新王?!

大家好&#xff0c; 我是不爱敲代码吖,2024 年 6 月最新的 TIOBE 编程语言排行榜已经发布&#xff0c;如图&#xff1a; 注意&#xff0c;TIOBE 编程语言排行榜是基于 全球 工程师的数量、课程、热门网站、第三方供应商综合计算出来的&#xff0c;只是一个编程语言流行度和趋势…

MBTI:探索你的性格类型

人不走空 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌赋&#xff1a;斯是陋室&#xff0c;惟吾德馨 目录 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌…