亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

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

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

概述

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

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

一、CROSS APPLY

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

查詢每個學生最近兩次的考試成績。

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

結果:

二、OUTER APPLY

OUTER APPLY 的意思是“外部應用”,與 CROSS APPLY 的原理一致,只是在匹配失敗時,左表與右表也將合并為一條記錄輸出,不過右表的輸出字段為null。(與 LEFT OUTER JOIN 類似)

查詢每個學生最近兩次的考試成績,沒有參加考試的同學成績補 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

結果:

三、應用場景

1.結合表值函數(shù)使用:

有一張表是這樣的:

很簡單的一張表,就一個字段num,我想把這個字段的int型數(shù)字分別轉化成二進制八進制和十六進制的數(shù)值,有現(xiàn)成的進制轉化的表值函數(shù)。

SELECT * FROM #T a CROSS APPLY [dbo].[F_TConversion](a.num)

總結一下:如果查詢結果集需要用到表值函數(shù)對某個字段的值進行處理的話,請使用CROSS APPLY~

2.top子查詢的用法:

有一張學生表,分別name,學科,分數(shù) 這三個字段,如下:

我要看語文第一名,數(shù)學前兩名,英語前三名的name,學科,分數(shù),用cross apply實現(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

到此這篇關于SQL Server使用CROSS APPLY與OUTER APPLY實現(xiàn)連接查詢的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支持。

標簽: MsSQL
相關文章:
主站蜘蛛池模板: 国产黄色片在线播放 | 国产乱码精品一区二区三区四川 | 91精品国产综合久久欧美 | 香蕉网站狼人久久五月亭亭 | 特黄一级大片 | 欧美 日韩 中字 国产 | 日韩视频一区二区 | 国产成人精品亚洲日本在线观看 | 国产精品自产拍2021在线观看 | 国产最新凸凹视频免费 | 国产精品嫩草影院99av视频 | 国产激情视频在线 | 成年男女男精品免费视频网站 | 欧美一级视频在线观看 | 伊人影院在线观看视频 | 49pao强力免费打造在线高清 | 国产在线精品一区二区不卡 | 香蕉久久高清国产精品免费 | 国产高清国产专区国产精品 | 免费亚洲黄色 | 国产精品久久久久999 | mm在线视频免费看 | 久久亚洲精品一区二区三区浴池 | 亚洲一在线 | 久久被窝电影亚洲爽爽爽 | 日本 国产 欧美 | 亚洲国产一区二区在线 | 欧美成人r级在线播放 | 黄在线观看www免费看 | 成人爽爽激情在线观看 | 亚洲国产美女视频 | 中国一级黄 | a级做爰毛片视频免费看 | 精品综合久久久久久8888 | 久久国产影视免费精品 | 国产dvd毛片在线视频 | 国产免费久久精品99re丫y | 亚洲高清视频在线观看 | 日韩视频一区二区三区 | 亚洲狼人综合干 | 黄色视屏免费在线观看 |