網站首頁 編程語言 正文
概述
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
原文鏈接:https://www.cnblogs.com/springsnow/p/10286490.html
相關推薦
- 2024-01-29 在DOS或Windows環境中,使用工具Debug
- 2022-11-25 Vmware臨時文件存放路徑_VMware
- 2022-12-07 C++AVL樹4種旋轉詳講(左單旋、右單旋、左右雙旋、右左雙旋)_C 語言
- 2022-10-29 線性回歸(基于python的理論與實現)的RuntimeWaring溢出問題
- 2022-08-11 python中的多線程鎖lock=threading.Lock()使用方式_python
- 2022-10-14 Mybatis一對多使用PageHelper分頁遇到的問題
- 2022-05-26 Flutter?Drawer抽屜菜單示例詳解_Android
- 2023-10-11 nginx:connect() failed (111: Connection refused) w
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支