• 技术文章 >数据库 >SQL

    SQL Server使用CROSS APPLY与OUTER APPLY实现连接查询

    WBOYWBOY2022-08-26 14:07:24转载559
    本篇文章给大家带来了关于SQL server的相关知识,其中主要介绍了SQL Server使用CROSS APPLY与OUTER APPLY实现连接查询的方法,文中通过示例代码介绍的非常详细,下面一起来看一下,希望对大家有帮助。

    php入门到就业线上直播课:进入学习

    推荐学习:《SQL教程

    概述

    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

    推荐学习:《SQL教程

    以上就是SQL Server使用CROSS APPLY与OUTER APPLY实现连接查询的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:脚本之家,如有侵犯,请联系admin@php.cn删除

    千万级数据并发解决方案(理论+实战):点击学习

    Mysql单表千万级数据量的查询优化与性能分析

    Mysql主从原理及其在高并发系统中的应用

    专题推荐:SQL
    上一篇:SQL Server备份数据库的完整步骤 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• MySQL中的日期时间类型与格式化方式总结• 一起分析MySQL中replace into与replace区别• MySQL中数据库优化的常见sql语句(总结分享)• 什么是死锁?聊聊对MySQL死锁的理解• MySQL日志专项整理之redo log和undo log
    1/1

    PHP中文网