久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

SQL?Server怎么使用CROSS?APPLY與OUTER?APPLY實現連接查詢

162次閱讀
沒有評論

共計 1515 個字符,預計需要花費 4 分鐘才能閱讀完成。

行業資訊    
數據庫    
SQL?Server 怎么使用 CROSS?APPLY 與 OUTER?APPLY 實現連接查詢

本篇內容主要講解“SQL Server 怎么使用 CROSS APPLY 與 OUTER APPLY 實現連接查詢”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓丸趣 TV 小編來帶大家學習“SQL Server 怎么使用 CROSS APPLY 與 OUTER APPLY 實現連接查詢”吧!

概述

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

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

一、CROSS APPLY

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

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

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

結果:

二、OUTER APPLY

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

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

結果:

三、應用場景 1. 結合表值函數使用:

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

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

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

2.top 子查詢的用法:

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

我要看語文第一名,數學前兩名,英語前三名的 name,學科,分數,用 cross apply 實現方法如下:

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 實現連接查詢”有了更深的了解,不妨來實際操作一番吧!這里是丸趣 TV 網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

正文完
 
丸趣
版權聲明:本站原創文章,由 丸趣 2023-07-13發表,共計1515字。
轉載說明:除特殊說明外本站除技術相關以外文章皆由網絡搜集發布,轉載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 公主岭市| 依安县| 广元市| 威海市| 通河县| 乌海市| 收藏| 礼泉县| 尤溪县| 胶州市| 绵阳市| 龙里县| 务川| 伊春市| 栾城县| 深圳市| 博野县| 科技| 汝城县| 古蔺县| 郎溪县| 黎川县| 临安市| 招远市| 涿州市| 普安县| 屏南县| 英超| 石景山区| 婺源县| 怀安县| 汉源县| 宜宾市| 将乐县| 临夏市| 怀仁县| 绥中县| 衡阳县| 河东区| 仪征市| 芜湖市|