首頁 > 資料庫 > SQL > 主體

SQL Server使用CROSS APPLY與OUTER APPLY實現連線查詢

WBOY
發布: 2022-08-26 14:07:24
轉載
2073 人瀏覽過

這篇文章為大家帶來了關於SQL server的相關知識,其中主要介紹了SQL Server使用CROSS APPLY與OUTER APPLY實現連接查詢的方法,文中透過範例程式碼介紹的非常詳細,下面一起來看一下,希望對大家有幫助。

SQL Server使用CROSS APPLY與OUTER APPLY實現連線查詢

推薦學習:《SQL教學

#概述

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教學

以上是SQL Server使用CROSS APPLY與OUTER APPLY實現連線查詢的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
sql
來源:jb51.net
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!