首頁 > 資料庫 > mysql教程 > sqlserver技术内幕<二> 表运算符之apply

sqlserver技术内幕<二> 表运算符之apply

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
發布: 2016-06-07 15:33:26
原創
1326 人瀏覽過

SQL SERVER 2005新增了APPLY运算符。该运算符有些类于表连接(JOIN),但是功能却有不同。APPLY的右表表达式可以引用左输入中的列。在JOIN运算的时候,连接的2个表之间没有优先级,但是使用APPLY时,就像先计算左表输入,然后为左输入中的每一行计算一次右输

SQL SERVER 2005新增了APPLY运算符。该运算符有些类似于表连接(JOIN),但是功能却有不同。APPLY的右表表达式可以引用左输入中的列。在JOIN运算的时候,连接的2个表之间没有优先级,但是使用APPLY时,就像先计算左表输入,然后为左输入中的每一行计算一次右输入。

    APPLY分为CROSS APPLY和OUTER APPLY。CROSS APPLY的外部(左)行应用内部(右)表表达式时返回空集,则不返回该行,这个有点类似于INNER JOIN。而OUTER APPLY将返回该行,并且该行的内表表达式的属性是NULL,类似于OUTER JOIN。

    例如以下的代码是查询每个客户最新的2个订单。运用了CROSS APPLY运算符,在右部的计算中可以使用左部计算的结果,但是APPLY需要最终取个别名(CA),这点很让人困惑,也许是SQL SERVER内部解析器的需要。

    SELECT C.customerid, city, orderid
    FROM dbo.Customers AS C
       CROSS APPLY
        (SELECT TOP(2) orderid, customerid
         FROM dbo.Orders AS O
         WHERE O.customerid = C.customerid
         ORDER BY orderid DESC) AS CA;

    以上查询的结果如下:

    customerid                  city                    orderid

    Gerrard                         Liverpool                  2

    Gerrard                         Liverpool                  1

    Suarez                          Liverpool                  5

    Suarez                          Liverpool                  4

    Casillas                        Madrid                     6    

 

    在以上的查询中,如果客户Carragher没有订单,则不会出现Carragher的记录,因为使用的是CROSS APPLY。如果想返回没有订单的客户,需要使用OUTER APPLY。

    SELECT C.customerid, city, orderid
    FROM dbo.Customers AS C
       OUTER APPLY
        (SELECT TOP(2) orderid, customerid
         FROM dbo.Orders AS O
         WHERE O.customerid = C.customerid
         ORDER BY orderid DESC) AS CA;

    查询的结果如下:

    customerid                  city                    orderid

    Carragher                       Liverpool                  NULL

    Gerrard                         Liverpool                  2

    Gerrard                         Liverpool                  1

    Suarez                          Liverpool                  5

    Suarez                          Liverpool                  4

    Casillas                        Madrid                     6    

 

 

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
tp6連線sqlserver資料庫問題
來自於 1970-01-01 08:00:00
0
0
0
php 如何呼叫sqlserver的分頁儲存過程
來自於 1970-01-01 08:00:00
0
0
0
php 7.2.10 連結 SQLserver2008r2 報錯
來自於 1970-01-01 08:00:00
0
0
0
Laravel 中無法連線 SQL Server
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板