SQL Server怎么使用CROSS APPLY与OUTER APPLY实现连接查询
本篇内容主要讲解“SQLServer怎么使用CROSSAPPLY与OUTERAPPLY实现连接查询”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“SQLServer怎么使用CROSSAPPLY与OUTERAPPLY实现连接查询”吧!
概述CROSS APPLY 与 OUTER APPLY 可以做到:
左表一条关联右表多条记录时,我需要控制右表的某一条或多条记录跟左表匹配的情况。
有两张表:Student(学生表)和 Score(成绩表),数据如下:
一、CROSS APPLYROSS APPLY 的意思是“交叉应用”,在查询时首先查询左表,,然后右表的每一条记录跟左表的当前记录进行匹配。匹配成功则将左表与右表的记录合并为一条记录输出;匹配失败则抛弃左表与右表的记录。(与 INNER JOIN 类似)
查询每个学生最近两次的考试成绩。
SELECTT1.StudentNo,T1.Name,T2.ExamScore,T2.ExamDateFROMStudentAST1CROSSAPPLY(SELECTTOP2*FROMScoreASTWHERET1.StudentNo=T.StudentNoORDERBYT.ExamDateDESC)AST2
结果:
二、OUTER APPLYOUTER APPLY 的意思是“外部应用”,与 CROSS APPLY 的原理一致,只是在匹配失败时,左表与右表也将合并为一条记录输出,不过右表的输出字段为null。(与 LEFT OUTER JOIN 类似)
查询每个学生最近两次的考试成绩,没有参加考试的同学成绩补 null
SELECTT1.StudentNo,T1.Name,T2.ExamScore,T2.ExamDateFROMStudentAST1OUTERAPPLY(SELECTTOP2*FROMScoreASTWHERET1.StudentNo=T.StudentNoORDERBYT.ExamDateDESC)AST2
结果:
三、应用场景1.结合表值函数使用:很简单的一张表,就一个字段num,我想把这个字段的int型数字分别转化成二进制八进制和十六进制的数值,有现成的进制转化的表值函数。
SELECT*FROM#TaCROSSAPPLY[dbo].[F_TConversion](a.num)
总结一下:如果查询结果集需要用到表值函数对某个字段的值进行处理的话,请使用CROSS APPLY~
2.top子查询的用法:有一张学生表,分别name,学科,分数 这三个字段,如下:
我要看语文第一名,数学前两名,英语前三名的name,学科,分数,用cross apply实现方法如下:
SELECTb.*FROM(selectSubject='Chiness',num=1unionallselect'Math',2unionallselect'English',3)acrossapply(selecttop(a.num)*fromStudentswhereSubject=a.Subject)b
到此,相信大家对“SQLServer怎么使用CROSSAPPLY与OUTERAPPLY实现连接查询”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。