日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

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


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


概述

CROSS APPLY 與 OUTER APPLY 可以做到:

左表一條關聯右表多條記錄時,我需要控制右表的某一條或多條記錄跟左表匹配的情況。

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


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


一、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

結果:


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


二、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

結果:


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


三、應用場景

1、結合表值函數使用:

有一張表是這樣的:


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


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

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


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

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

2、top子查詢的用法:

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


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


我要看語文第一名,數學前兩名,英語前三名的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實現連接查詢



分享到:
標簽:SQLServer CROSSAPPLY OUTERAPPLY 連接查詢
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定