SQL 关于apply的两种形式cross apply 和 outer apply
 
apply有两种形式: cross apply 和 outer apply
 
先看看语法:
 
<left_table_expression>  {cross|outer} apply <right_table_expression>
 
再让我们了解一下apply运算涉及的两个步骤:
 
A1:把右表表达式(<right_table_expression>)应用到左表(<left_table_expression>)输入的行;
A2:添加外部行;
  使用apply就像是先计算左输入,让后为左输入中的每一行计算一次右输入。(这一句很重要,可能会不理解,但要先记住,后面会有详细的说明)
 
最后结合以上两个步骤说明cross apply和outer apply的区别:
 
  cross apply和outer apply 总是包含步骤A1,只有outer apply包含步骤A2,如果cross apply左行应用右表表达式时返回空积,则不返回该行。而outer apply返回该行,并且该行的右表表达式的属性为null。
 
看到上面的解释或步骤大家可能还是一头的雾水,不知所云。下面用例子来说明:
 
先建表一([dbo].[Customers]  字段说明:customerid -- 消费者id , city -- 所在城市):
CREATE TABLE [dbo].[Customers](

    [customerid] [char](5) COLLATE Chinese_PRC_CI_AS NOT NULL,

    [city] [varchar](10) COLLATE Chinese_PRC_CI_AS NOT NULL,

PRIMARY KEY CLUSTERED 

(

    [customerid] ASC

)WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY]

) ON [PRIMARY]

向表一插入数据:

insert into dbo.Customers values('FISSA','Madrid');

insert into dbo.Customers values('FRNDO','Madrid');

insert into dbo.Customers values('KRLOS','Madrid');

insert into dbo.Customers values('MRPHS','Zion');

查询所插入的数据:

select * from dbo.Customers

结果如图:

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

CREATE TABLE [dbo].[Orders](

    [orderid] [int] NOT NULL,

    [customerid] [char](5) COLLATE Chinese_PRC_CI_AS NULL,

PRIMARY KEY CLUSTERED 

(

    [orderid] ASC

)WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY]

) ON [PRIMARY]

向表二插入数据:

insert into dbo.Orders values(1,'FRNDO');

insert into dbo.Orders values(2,'FRNDO');

insert into dbo.Orders values(3,'KRLOS');

insert into dbo.Orders values(4,'KRLOS');

insert into dbo.Orders values(5,'KRLOS');

insert into dbo.Orders values(6,'MRPHS');

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

查询插入的数据:

select * from dbo.orders

结果如图:

例子:题目:得到每个消费者最新的两个订单:
 
用cross apply
select *

from dbo.Customers as C

 cross apply

    (select top 2 *

     from dbo.Orders as O

     where C.customerid=O.customerid

     order by orderid desc) as CA

结果如图:

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

from dbo.Customers as C

 outer apply

    (select top 2 *

     from dbo.Orders as O

     where C.customerid=O.customerid

     order by orderid desc) as CA

结果如图:

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

SQL关于apply的两种形式cross apply和outer apply(转载)的更多相关文章

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

    SQL 关于apply的两种形式cross apply 和 outer apply 例子: CREATE TABLE [dbo].[Customers]( ) COLLATE Chinese_PRC_ ...

  2. 转:SQL 关于apply的两种形式cross apply 和 outer apply

    原文地址:http://www.cnblogs.com/Leo_wl/archive/2013/04/02/2997012.html SQL 关于apply的两种形式cross apply 和 out ...

  3. SQL 关于apply的两种形式cross apply 和 outer apply(转)

    转载链接:http://www.cnblogs.com/shuangnet/archive/2013/04/02/2995798.html apply有两种形式: cross apply 和 oute ...

  4. SQL 关于apply的两种形式cross apply 和 outer apply, with cube 、with rollup 和 grouping

    1). apply有两种形式: cross apply 和 outer apply先看看语法: <left_table_expression> {cross|outer} apply &l ...

  5. C# ASP.NET(配置数据库 sql server 地址的两种形式以及配置信息的获取)

    ( 1 ) 数据库装在本机,并且采用windows认证模式 <connectionStrings>    <add name="SQLConnectionString&qu ...

  6. 在sql中case子句的两种形式

    case子句,在select后面可以进行逻辑判断. 两种形式:判断相等.判断不等 一.判断相等的语法: case 列名 when ...  then ... when ...  then ... el ...

  7. MyBatis collection的两种形式——MyBatis学习笔记之九

    与association一样,collection元素也有两种形式,现介绍如下: 一.嵌套的resultMap 实际上以前的示例使用的就是这种方法,今天介绍它的另一种写法.还是以教师映射为例,修改映射 ...

  8. 基于 Scrapy-redis 两种形式的分布式爬虫

    基于 Scrapy-redis 两种形式的分布式爬虫 .caret, .dropup > .btn > .caret { border-top-color: #000 !important ...

  9. C++:一般情况下,设计函数的形参只需要两种形式

    C++:一般情况下,设计函数的形参只需要两种形式.一,是引用形参,例如 void function (int &p_para):二,是常量引用形参,例如 void function(const ...

随机推荐

  1. iOS NSURLSession 下载

    周五的时候,有个新的需求,要下载脚本,帮助玩家自动打怪,应该也是挂机的意思吧! 组长让我设计界面,让汤老师设计数据等.我觉得数据的挑战性更大一点,然后就接过来了. 自己还没有形成互联网思维,所以弄了一 ...

  2. iOS开发中(null)与<null>的判断

    判断(null): if(m_result==nil) {      NSLog(@"KDA!"); } 判断<null>: if([m_result isEqual: ...

  3. 通过iphone蓝牙与经过苹果MFI授权认证的硬件通讯,传输图片(转)

    http://blog.csdn.net/hwj2012/article/details/7883711 相关: http://blog.csdn.net/xufeidll/article/detai ...

  4. JQuery: JQuery效果(隐藏、显示、切换,滑动,淡入淡出,以及动画)

    JQuery:效果 JQuery效果有很多,包括隐藏.显示.切换,滑动,淡入淡出,以及动画等.隐藏:JQuery hide() 显示:JQuery show() 切换:JQuery toggle() ...

  5. Linux中的元字符和转义符 单引号 硬引号 双引号 软引号

    Linux中的元字符和转义符  单引号  硬引号  双引号  软引号 Linux就这个范儿 Linux就这个范儿 P182单引号:硬引号,所有元字符特殊意义都会关掉双引号:软引号,只允许出现特定元字符 ...

  6. jquery对于table的操作

    $("#datable tr").eq(0).children("td").eq(0).html()   //获得某行某列的值

  7. XUtils框架中HttpUtils使用Get请求时总是返回相同信息的问题解决,xutilshttputils

    如需转载请标明出处:http://blog.csdn.net/itas109 版本:Xutils 2014年11月11日 下载地址:https://github.com/wyouflf/xUtils ...

  8. RFS_oracle的操作

    1. cx_Oracle Python 连接Oracle 数据库,需要使用cx_Oracle 包. 该包的下载地址:http://cx-Oracle.sourceforge.net/ 下载的时候,注意 ...

  9. CentOS 配置本地yum源

    [root@localhost ~]#ls /media/dvd/                                                                   ...

  10. AVAudioPlayer init 报错: Error Domain=NSOSStatusErrorDomain Code=1937337955

    Error Domain=NSOSStatusErrorDomain Code=1937337955 原因: 音频文件的格式不规范导致 对于iOS7以上的系统(含iOS7),在确定文件格式的情况下可以 ...