zoukankan      html  css  js  c++  java
  • [转]CROSS APPLY 和outer apply 的区别

    CROSS APPLY 和outer apply 的区别:

    DECLARE @t table (姓名 varchar(10))
    insert into @T values('张三')
    insert into @T values('李四')
    insert into @T values('王二')
    insert into @T values(NULL )


    DECLARE @T2 table (姓名 varchar(10) , 课程 varchar(10) , 分数 int)
    insert into @T2 values('张三' , '语文' , 74)
    insert into @T2 values('张三' , '数学' , 83)
    insert into @T2 values('张三' , '物理' , 93)
    insert into @T2 values('李四' , '物理' , 91)
    insert into @T2 values(NULL , '数学' , 50)


    select * from @T a
    cross apply
        (
    select 课程,分数 from @t2 where 姓名=a.姓名) b

    /*
    姓名         课程         分数
    ---------- ---------- -----------
    张三         语文         74
    张三         数学         83
    张三         物理         93
    李四         物理         91

    (4 行受影响)
    */

    select 
        
    * 
    from 
        
    @T a
    outer apply
        (
    select 课程,分数 from @t2 where 姓名=a.姓名) b
    /*
    姓名         课程         分数
    ---------- ---------- -----------
    张三         语文         74
    张三         数学         83
    张三         物理         93
    李四         物理         91
    王二         NULL       NULL
    NULL       NULL       NULL

    (6 行受影响)
    */
  • 相关阅读:
    C++中整型变量的存储大小和范围
    A1038 Recover the Smallest Number (30 分)
    A1067 Sort with Swap(0, i) (25 分)
    A1037 Magic Coupon (25 分)
    A1033 To Fill or Not to Fill (25 分)
    A1070 Mooncake (25 分)
    js 获取控件
    C#代码对SQL数据库添加表或者视图
    JS 动态操作表格
    jQuery取得下拉框选择的文本与值
  • 原文地址:https://www.cnblogs.com/sofire/p/1717928.html
Copyright © 2011-2022 走看看