這篇文章為大家帶來了關於SQL server的相關知識,其中主要介紹了SQL Server使用CROSS APPLY與OUTER APPLY實現連接查詢的方法,文中透過範例程式碼介紹的非常詳細,下面一起來看一下,希望對大家有幫助。
推薦學習:《SQL教學》
CROSS APPLY 與OUTER APPLY 可以做到:
左表一筆關聯右表多筆記錄時,我需要控制右表的某一筆或多筆記錄跟左表相符的情況。
有兩張表:Student(學生表)和Score(成績表),數據如下:
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
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
SELECT * FROM #T a CROSS APPLY [dbo].[F_TConversion](a.num)
##我要看語文第一名,數學前兩名,英語前三名的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中文網其他相關文章!