濮阳杆衣贸易有限公司

主頁 > 知識庫 > SQLServer APPLY表運算符使用介紹

SQLServer APPLY表運算符使用介紹

熱門標簽:海南自動外呼系統(tǒng)價格 松原導(dǎo)航地圖標注 創(chuàng)業(yè)電銷機器人 電銷機器人虛擬號碼 浙江地圖標注 舞鋼市地圖標注app 沈陽智能外呼系統(tǒng)代理 九鹿林外呼系統(tǒng)怎么收費 滄州營銷外呼系統(tǒng)軟件
新增的APPLY表運算符把右表表達式應(yīng)用到左表表達式中的每一行。它不像JOIN那樣先計算那個表表達式都可以,APPLY必選先邏輯地計算左表達式。這種計算輸入的邏輯順序允許吧右表達式關(guān)聯(lián)到左表表達式。

  APPLY有兩種形式,一個是OUTER APPLY,一個是CROSS APPLY,區(qū)別在于指定OUTER,意味著結(jié)果集中將包含使右表表達式為空的左表表達式中的行,而指定CROSS,則相反,結(jié)果集中不包含使右表表達式為空的左表表達式中的行。

  用幾個例子解釋這個會更清晰。

  例1:CROSS APPLY 形式

  比如:LargeTable表中的某一列存儲的數(shù)據(jù)是以“:”號分隔的數(shù)據(jù),我們處理的時候,可能要先把這個值,先分隔,然后把分隔后的每個值單獨一行放在一張表中,然后對這個表做處理。

  原始數(shù)據(jù)(LargeTable表):
  

  為了簡單,我們先拿其中id=2的一行處理,這些以:號分隔的數(shù)據(jù),可能是我們某張表的主鍵(t1),我們可能需要把這些數(shù)值提出來,放在一張臨時表中,和t1表關(guān)聯(lián),做一些處理。

  處理這個分隔的數(shù)據(jù)結(jié)果如下圖:

  

  如果用之前的版本處理這個操作的話,應(yīng)該很發(fā)雜,暫時沒想到怎么處理,如果有人實現(xiàn)過,可以提示一下。

  這只是用其中一行做的處理,如果我們用上圖的3行都做這樣處理,把三行以:號分隔的數(shù)值都放在一個表中,該怎么處理呢?

  今天的主角APPLY該閃亮登場了。用APPLY表運算符一行語句就能處理以上操作。

復(fù)制代碼 代碼如下:

SELECT a FROM dbo.LargeTable AS LT --實際表
CROSS APPLY dbo.split(LT.Name,':') --自定義表值函數(shù),處理以某個字符分隔的數(shù)據(jù),把這些數(shù)據(jù),返回一張表
WHERE a > '' --去掉結(jié)果表中a字段為空的數(shù)據(jù)

處理的結(jié)果如下圖:

  

  是不是很簡單。
     需要額外定義的就是那個自定義表值函數(shù)(split),這是我在網(wǎng)上找的,類似.Net中Split操作,代碼如下:

復(fù)制代碼 代碼如下:

/*
使用方法:SELECT * FROM dbo.split('581::579::519::279::406::361::560',':')
*/
ALTER Function [dbo].[Split](@Sql varchar(8000),@Splits varchar(10))
returns @temp Table (a varchar(100))
As
Begin
Declare @i Int
Set @Sql = RTrim(LTrim(@Sql))
Set @i = CharIndex(@Splits,@Sql)
While @i >= 1
Begin
Insert @temp Values(Left(@Sql,@i-1))
Set @Sql = SubString(@Sql,@i+1,Len(@Sql)-@i)
Set @i = CharIndex(@Splits,@Sql)
End
If @Sql > ''
Insert @temp Values (@Sql)
Return
End

例2:OUTER APPLY 形式

  場景:有個供貨商表(Supplier)和供貨商產(chǎn)品表(Products),我們要取每一個供貨商中單價最高的兩個產(chǎn)品。

  供貨商表:

  

  供貨商產(chǎn)品表:

  

  首先,我們創(chuàng)建一個自定義表值函數(shù)(dbo.fn_top_products),該函數(shù)根據(jù)供貨商ID返回單價最高的兩個商品。

復(fù)制代碼 代碼如下:

IF OBJECT_ID('dbo.fn_top_products') IS NOT NULL
DROP FUNCTION dbo.fn_top_products;
GO
--根據(jù)供貨商ID獲得單價最高的兩件商品
CREATE FUNCTION dbo.fn_top_products
(@supid AS INT)
RETURNS TABLE
AS
RETURN
SELECT TOP(2)Id AS ProductId,ProductName,UnitPrice
FROM dbo.Products
WHERE SupplierId = @supid
ORDER BY UnitPrice DESC
GO

好,前期的數(shù)據(jù)都已經(jīng)準備好了,下面讓我們試試用OUTER APPLY形式來查詢,會出現(xiàn)什么結(jié)果。
執(zhí)行以下語句:
復(fù)制代碼 代碼如下:

SELECT S.id AS SupplierId,S.CompanyName,UnitPrice FROM dbo.Supplier AS S
OUTER APPLY dbo.fn_top_products(S.id) AS P

執(zhí)行結(jié)果如下:

   

  注意最后為NULL的記錄,reed公司因為沒有商品,所以單價為NULL了。

  如果用CROSS APPLY形式,執(zhí)行以下查詢:


復(fù)制代碼 代碼如下:

SELECT S.id AS SupplierId,S.CompanyName,UnitPrice FROM dbo.Supplier AS S
CROSS APPLY dbo.fn_top_products(S.id) AS P 

生成的輸出結(jié)果如下:

    

  大家看出OUTER APPLY和CROSS APPLY的區(qū)別了吧。

  再次說一下APPLY的執(zhí)行過程,它先邏輯計算左表表達式(以上的LargeTable表),然后把右表達式(以上的自定義表值函數(shù)Split)應(yīng)用到左表表達式的每一行。實際是把外部查詢的列引用作為參數(shù)傳遞給表值函數(shù)。

標簽:公主嶺 寶雞 咸寧 日喀則 商洛 西藏 臺灣 巨人網(wǎng)絡(luò)通訊聲明:本文標題《SQLServer APPLY表運算符使用介紹》,本文關(guān)鍵詞  SQLServer,APPLY,表,運算符,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。

  • 相關(guān)文章
  • 下面列出與本文章《SQLServer APPLY表運算符使用介紹》相關(guān)的同類信息!
  • 本頁收集關(guān)于SQLServer APPLY表運算符使用介紹的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    大足县| 涟源市| 普安县| 津南区| 宜丰县| 朝阳区| 榕江县| 临颍县| 吉林省| 桐庐县| 金昌市| 鹿邑县| 河北区| 惠东县| 正镶白旗| 翁源县| 嘉荫县| 桐梓县| 盘锦市| 汕尾市| 固阳县| 台安县| 红桥区| 开鲁县| 胶南市| 镶黄旗| 阿鲁科尔沁旗| 神农架林区| 阳高县| 寿阳县| 汾阳市| 昭苏县| 平昌县| 邵武市| 隆德县| 汕尾市| 兰溪市| 剑阁县| 望都县| 利辛县| 剑川县|