加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

cross apply与outer apply咋做连接查询的

发布时间:2023-05-08 14:15:49 所属栏目:MsSql教程 来源:
导读:这篇给大家分享的知识是“cross apply与outer apply怎么做连接查询的”,小编觉得挺不错的,对大家学习或是工作可能会有所帮助,对此分享发大家做个参考,希望这篇“cross apply与outer apply怎么做连
这篇给大家分享的知识是“cross apply与outer apply怎么做连接查询的”,小编觉得挺不错的,对大家学习或是工作可能会有所帮助,对此分享发大家做个参考,希望这篇“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
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章