数据库教程:SQL Server使用CROSS APPLY与OUTER APPLY实现连接查询

概述cross apply 与 outer apply 可以做到:左表一条关联右表多条记录时,我需要控制右表的某一条或多条记录跟左表匹配的情况。有两张表:student(学生表)和 score(成绩表


概述

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实现连接查询

到此这篇关于sql server使用cross apply与outer apply实现连接查询的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持<计算机技术网(www.ctvol.com)!!>。

需要了解更多数据库技术:SQL Server使用CROSS APPLY与OUTER APPLY实现连接查询,都可以关注数据库技术分享栏目—计算机技术网(www.ctvol.com)!

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/dtteaching/1238367.html

(0)
上一篇 2022年9月11日
下一篇 2022年9月11日

精彩推荐