提示 (Transact-SQL) - Join

適用於:SQL ServerAzure SQL DatabaseAzure SQL 受控執行個體

聯結提示會指定查詢最佳化工具強制執行 SQL Server 中兩份資料表之間的聯結策略。 如需有關聯結和聯結語法的一般資訊,請參閱 FROM (Transact-SQL)

警告

由於 SQL Server 查詢最佳化工具通常會選取最好的查詢執行計劃,因此我們建議只有資深的開發人員和資料庫管理員才應該使用提示,並將其當作最後的解決辦法。

適用於

Transact-SQL 語法慣例

Syntax

<join_hint> ::=   
     { LOOP | HASH | MERGE | REMOTE }  

注意

若要檢視 SQL Server 2014 (12.x) 和舊版的 Transact-SQL 語法,請參閱 舊版檔

引數

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

下列範例指定查詢中的 JOIN 作業由 HASH 聯結執行。 此範例使用 AdventureWorks2022 資料庫。

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

下列範例指定查詢中的 JOIN 作業由 LOOP 聯結執行。 此範例使用 AdventureWorks2022 資料庫。

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

下列範例指定查詢中的 JOIN 作業由 MERGE 聯結執行。 此範例使用 AdventureWorks2022 資料庫。

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  

另請參閱

提示 (Transact-SQL)