• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

SQL 关于apply的两种形式cross apply 和 outer apply

mysql 搞代码 4年前 (2022-01-09) 10次浏览 已收录 0个评论

SQL 关于apply的两种形式cross apply 和 outer apply apply有两种形式: cross apply 和 outer apply 先看看语法: left_table_expression {cross|outer} apply right_table_expression 再让我们了解一下apply运算涉及的两个步骤: A1 :把右表表达式( right_

SQL 关于apply的两种形式cross app

本文来源gao!%daima.com搞$代*!码网1

ly 和 outer apply

apply有两种形式: cross apply 和 outer apply

先看看语法:

   {cross|outer} apply

再让我们了解一下apply运算涉及的两个步骤:

  • A1:把右表表达式()应用到左表()输入的行;
  • A2:添加外部行;
  •   使用apply就像是先计算左输入,让后为左输入中的每一行计算一次右输入。(这一句很重要,可能会不理解,但要先记住,后面会有详细的说明)

    最后结合以上两个步骤说明cross apply和outer apply的区别:

      cross apply和outer apply 总是包含步骤A1,只有outer apply包含步骤A2如果cross apply左行应用右表表达式时返回空积,则不返回该行。而outer apply返回改行,并且改行的右表表达式的属性为null。

    看到上面的解释或步骤大家可能还是一头的雾水,不知所云。下面用例子来说明:

    , city — 所在城市):

    .((5) COLLATE Chinese_PRC_CI_AS NOT NULL,(10) COLLATE Chinese_PRC_CI_AS NOT NULL, ())

    向表一插入数据:

    ,);,);,);,);

    查询所插入的数据:

    dbo.Customers

    结果如图:

    再建表二([dbo].[Orders] 字段说明:orderid — 订单id , customerid — 消费者id):

    .(,(5) COLLATE Chinese_PRC_CI_AS NULL, ())

    向表二插入数据:

    ););););););insert into dbo.Orders values(7,null);

    查询插入的数据:

    dbo.orders

    结果如图:

    例子:题目:得到每个消费者最新的两个订单:

    用cross apply

    sql:

    dbo.Customers as C cross apply(dbo.Orders as Owhere C.customerid=O.customeridorder by orderid desc) as CA

    结果如图:

    过程分析:

      它是先得出左表【dbo.Customers】里的数据,然后把此数据一条一条的放入右表表式中,分别得出结果集,最后把结果集整合到一起就是最终的返回结果集了(T1的数据 像for循环一样 一条一条的进入到T2中 然后返回一个集合 最后把所有的集合整合到一块 就是最终的结果),网站空间,最后我们再理解一下上面让记着的话(使用apply就像是先计算左输入,让后为左输入中的每一行计算一次右输入)是不是有所明白了。

    实验:用outer apply 试试看看的到的结果:

    sql语句:

    dbo.Customers as C outer apply(dbo.Orders as Owhere C.customerid=O.customeridorder by orderid desc) as CA

    结果如图:

    结果分析:

      发现outer apply得到的结果比cross多了一行,我们结合上面所写的区别(cross apply和outer apply 总是包含步骤A1,虚拟主机,只有outer apply包含步骤A2如果cross apply左行应用右表表达式时返回空积,则不返回该行。而outer apply返回改行,并且改行的右表表达式的属性为null)就会知道了。

    ,香港虚拟主机


    搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
    转载请注明原文链接:SQL 关于apply的两种形式cross apply 和 outer apply

    喜欢 (0)
    [搞代码]
    分享 (0)
    发表我的评论
    取消评论

    表情 贴图 加粗 删除线 居中 斜体 签到

    Hi,您需要填写昵称和邮箱!

    • 昵称 (必填)
    • 邮箱 (必填)
    • 网址