SQL Server使用CROSS APPLY與OUTER APPLY實(shí)現(xiàn)連接查詢
概述
CROSS APPLY 與 OUTER APPLY 可以做到:
左表一條關(guān)聯(lián)右表多條記錄時(shí),我需要控制右表的某一條或多條記錄跟左表匹配的情況。
有兩張表:Student(學(xué)生表)和 Score(成績表),數(shù)據(jù)如下:

一、CROSS APPLY
ROSS APPLY 的意思是“交叉應(yīng)用”,在查詢時(shí)首先查詢左表,,然后右表的每一條記錄跟左表的當(dāng)前記錄進(jìn)行匹配。匹配成功則將左表與右表的記錄合并為一條記錄輸出;匹配失敗則拋棄左表與右表的記錄。(與 INNER JOIN 類似)
查詢每個(gè)學(xué)生最近兩次的考試成績。
SELECT T1.StudentNo, T1.Name, T2.ExamScore, T2.ExamDate FROM Student AS T1
CROSS APPLY
(
SELECT TOP 2 * FROM Score AS T
WHERE T1.StudentNo = T.StudentNo
ORDER BY T.ExamDate DESC
) AS T2結(jié)果:

二、OUTER APPLY
OUTER APPLY 的意思是“外部應(yīng)用”,與 CROSS APPLY 的原理一致,只是在匹配失敗時(shí),左表與右表也將合并為一條記錄輸出,不過右表的輸出字段為null。(與 LEFT OUTER JOIN 類似)
查詢每個(gè)學(xué)生最近兩次的考試成績,沒有參加考試的同學(xué)成績補(bǔ) null
SELECT T1.StudentNo, T1.Name, T2.ExamScore, T2.ExamDate FROM Student AS T1
OUTER APPLY
(
SELECT TOP 2 * FROM Score AS T
WHERE T1.StudentNo = T.StudentNo
ORDER BY T.ExamDate DESC
) AS T2結(jié)果:

三、應(yīng)用場(chǎng)景
1.結(jié)合表值函數(shù)使用:
有一張表是這樣的:

很簡(jiǎn)單的一張表,就一個(gè)字段num,我想把這個(gè)字段的int型數(shù)字分別轉(zhuǎn)化成二進(jìn)制八進(jìn)制和十六進(jìn)制的數(shù)值,有現(xiàn)成的進(jìn)制轉(zhuǎn)化的表值函數(shù)。
SELECT * FROM #T a CROSS APPLY [dbo].[F_TConversion](a.num)

總結(jié)一下:如果查詢結(jié)果集需要用到表值函數(shù)對(duì)某個(gè)字段的值進(jìn)行處理的話,請(qǐng)使用CROSS APPLY~
2.top子查詢的用法:
有一張學(xué)生表,分別name,學(xué)科,分?jǐn)?shù) 這三個(gè)字段,如下:

我要看語文第一名,數(shù)學(xué)前兩名,英語前三名的name,學(xué)科,分?jǐn)?shù),用cross apply實(shí)現(xiàn)方法如下:
SELECT b.* FROM (
select Subject='Chiness',num=1 union all
select 'Math',2 union all
select 'English',3) a
cross apply
(select top(a.num) * from Students where Subject=a.Subject ) b
到此這篇關(guān)于SQL Server使用CROSS APPLY與OUTER APPLY實(shí)現(xiàn)連接查詢的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
SQLSERVER 創(chuàng)建索引實(shí)現(xiàn)代碼
是SQL Server編排數(shù)據(jù)的內(nèi)部方法。它為SQL Server提供一種方法來編排查詢數(shù)據(jù)2012-04-04
SQL Server通過重建方式還原master數(shù)據(jù)庫
這篇文章主要為大家詳細(xì)介紹了SQL Server通過重建方式還原master數(shù)據(jù)庫的相關(guān)資料,需要的朋友可以參考下2016-09-09
sql server 自定義分割月功能詳解及實(shí)現(xiàn)代碼
這篇文章主要介紹了sql server 自定義分割月功能詳解及實(shí)現(xiàn)代碼的相關(guān)資料,需要的朋友可以參考下2016-10-10
小米正式開源 SQL 智能優(yōu)化與改寫工具 SOAR
SOAR,即 SQL Optimizer And Rewriter,是一款 SQL 智能優(yōu)化與改寫工具,由小米運(yùn)維 DBA 團(tuán)隊(duì)出品。下面通過本文給大家分享小米正式開源 SQL 智能優(yōu)化與改寫工具 SOAR,感興趣的朋友一起看看吧2018-11-11
一次SQL調(diào)優(yōu)數(shù)據(jù)庫性能問題后的過程(300W)
對(duì)單表超過300w+數(shù)據(jù)的Web應(yīng)用程序進(jìn)行測(cè)試后發(fā)現(xiàn)了一些功能、性能問題,采取了以下辦法來進(jìn)行調(diào)整2010-03-03
t-sql清空表數(shù)據(jù)的兩種方式示例(truncate and delete)
這篇文章主要介紹了t-sql使用truncate and delete清空表數(shù)據(jù)的兩種方法,大家參考使用2013-11-11
SQL根據(jù)指定分隔符分解字符串實(shí)現(xiàn)步驟
想要在MS SQL中根據(jù)給定的分隔符把這個(gè)字符串分解成各個(gè)元素,本文將詳細(xì)介紹此功能的實(shí)現(xiàn),需要了解的朋友可以參考下2012-11-11

