欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

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

程序员文章站 2022-06-05 20:37:48
...

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 apply 和 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 -- 所在城市