SQl inner LOOP | HASH | MERGE join--指定Join的方法

LOOP | HASH | MERGE

指定查詢中的聯結應該使用迴圈、雜湊或合併。 使用 LOOP |HASH | MERGE JOIN 會在兩份資料表之間強制執行特定聯結。 您無法同時使用 RIGHT 或 FULL,將 LOOP 指定為聯結類型。

REMOTE

指定在右資料表上執行聯結作業。 當左資料表是本機資料表,右資料表是遠端資料表時,這非常有用。 只有在左資料表的資料列數比右資料表少時,才應該使用 REMOTE。

如果右資料表是本機資料表,則聯結會在本機執行。 如果兩份資料表都在遠端,但來自不同的資料來源,REMOTE 會以右資料表為基礎來執行聯結。 如果兩份資料表都是遠端資料表,且來自相同資料來源,就不需要 REMOTE。

當利用 COLLATE 子句將聯結述詞所比較的其中一個值轉換成不同的定序時,便不能使用 REMOTE。

REMOTE 只能用於 INNER JOIN 作業。

聯結提示是在查詢的 FROM 子句中指定。 聯結提示會強制執行兩份資料表之間的聯結策略。 如果指定了兩份資料表的聯結提示,查詢最佳化工具會根據 ON 關鍵字的位置,自動強制執行查詢中所有聯結的資料表之聯結順序。 當使用不含 ON 子句的 CROSS JOIN 時,您可以用括號來指示聯結順序。

A.使用 HASH

下列範例指定由 HASH 聯結來執行查詢中的 JOIN 作業。

 
複製
USE AdventureWorks2012;
GO
SELECT p.Name, pr.ProductReviewID
FROM Production.Product AS p
LEFT OUTER HASH JOIN Production.ProductReview AS pr
ON p.ProductID = pr.ProductID
ORDER BY ProductReviewID DESC;

B.使用 LOOP

下列範例指定由 LOOP 聯結來執行查詢中的 JOIN 作業。

 
複製
USE AdventureWorks2012;
GO
DELETE FROM Sales.SalesPersonQuotaHistory 
FROM Sales.SalesPersonQuotaHistory AS spqh
    INNER LOOP JOIN Sales.SalesPerson AS sp
    ON spqh.SalesPersonID = sp.SalesPersonID
WHERE sp.SalesYTD > 2500000.00;
GO

C.使用 MERGE

下列範例指定由 MERGE 聯結來執行查詢中的 JOIN 作業。

 
複製
USE AdventureWorks2012;
GO
SELECT poh.PurchaseOrderID, poh.OrderDate, pod.ProductID, pod.DueDate, poh.VendorID 
FROM Purchasing.PurchaseOrderHeader AS poh
INNER MERGE JOIN Purchasing.PurchaseOrderDetail AS pod 
    ON poh.PurchaseOrderID = pod.PurchaseOrderID;
GO

转载于:https://www.cnblogs.com/Nina-piaoye/archive/2012/06/01/2529465.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值