国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

SQL Server使用CROSS APPLY與OUTER APPLY實(shí)現(xiàn)連接查詢

瀏覽:9日期:2023-03-06 14:25:23

概述

CROSS APPLY 與 OUTER APPLY 可以做到:
左表一條關(guān)聯(lián)右表多條記錄時(shí),我需要控制右表的某一條或多條記錄跟左表匹配的情況。

有兩張表:Student(學(xué)生表)和 Score(成績(jī)表),數(shù)據(jù)如下:

一、CROSS APPLY

ROSS APPLY 的意思是“交叉應(yīng)用”,在查詢時(shí)首先查詢左表,,然后右表的每一條記錄跟左表的當(dāng)前記錄進(jìn)行匹配。匹配成功則將左表與右表的記錄合并為一條記錄輸出;匹配失敗則拋棄左表與右表的記錄。(與 INNER JOIN 類似)

查詢每個(gè)學(xué)生最近兩次的考試成績(jī)。

SELECT T1.StudentNo, T1.Name, T2.ExamScore, T2.ExamDate FROM Student AS T1CROSS 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í),左表與右表也將合并為一條記錄輸出,不過(guò)右表的輸出字段為null。(與 LEFT OUTER JOIN 類似)

查詢每個(gè)學(xué)生最近兩次的考試成績(jī),沒(méi)有參加考試的同學(xué)成績(jī)補(bǔ) null

SELECT T1.StudentNo, T1.Name, T2.ExamScore, T2.ExamDate FROM Student AS T1OUTER 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è)字段,如下:

我要看語(yǔ)文第一名,數(shù)學(xué)前兩名,英語(yǔ)前三名的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í)有所幫助,也希望大家多多支持。

標(biāo)簽: MsSQL
相關(guān)文章:
主站蜘蛛池模板: 草草影院ccyy免费看片 | 国产美女作爱全过程免费视频 | 亚洲九九夜夜 | 午夜一级成人 | 国产一级毛片视频在线! | 欧美顶级毛片在线播放小说 | 国产亚洲区 | 欧美一级片免费在线观看 | 手机看a | 日韩一区二区三区四区 | 免费国产成人高清视频网站 | 成年女人免费看片 | 日韩欧一级毛片在线播无遮挡 | 国产在线观看成人免费视频 | 欧美成人午夜影院 | 欧美一区二区在线观看视频 | 亚洲精品美女国产一区 | 狠狠se| 亚洲一区视频在线播放 | 国产在线99| 亚洲香蕉影院 | 欧美亚洲国产精品久久高清 | 久久99国产综合精品 | 国产成人女人视频在线观看 | 久草草视频在线观看免费高清 | 一级毛片在线免费播放 | 在线成人毛片 | 一本久久a久久精品亚洲 | 中文字幕精品在线 | 精品国产九九 | 国产喷水女王在线播放 | 欧美成人性动漫在线观看 | 国产深夜福利视频网站在线观看 | 国产亚洲小视频 | 99久久精品国产片 | 欧美一级毛片高清视频 | 三级免费网站 | 亚洲三级毛片 | 中文字幕 亚洲精品 第1页 | 成年女人午夜免费视频 | 欧美高清一区二区三 |