zoukankan      html  css  js  c++  java
  • 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
  • 相关阅读:
    开发自定义控件步骤
    asp.net后台调用前台js代码
    使用ResolveUrl设置相对路径
    JavaScript获取后台C#变量以及调用后台方法
    使用jquery的验证插件进行客户端验证
    参数化的模糊查询
    使用Microsoft Enterprise Library 5.0记录日志信息
    我的Ajax学习笔记
    我的工作問題集(VS2005)
    存储过程从入门到精通(转载)
  • 原文地址:https://www.cnblogs.com/geass/p/2043953.html
Copyright © 2011-2022 走看看