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
posted @ 2012-06-01 08:30  Nina  阅读(1317)  评论(0编辑  收藏  举报