节85.1:联接提示
当两表联接时,查询优化器(QO)可在哈希、循环、合并三种联接算法间选择。若你确信已知最优算法,可强制指定:
-
内层循环联接
sqlSELECT TOP 100 * FROM Sales.Orders o INNER LOOP JOIN Sales.OrderLines ol ON o.OrderID = ol.OrderID; -
内层合并联接
sqlSELECT TOP 100 * FROM Sales.Orders o INNER MERGE JOIN Sales.OrderLines ol ON o.OrderID = ol.OrderID; -
内层哈希联接
sqlSELECT TOP 100 * FROM Sales.Orders o INNER HASH JOIN Sales.OrderLines ol ON o.OrderID = ol.OrderID;
节85.2:GROUP BY 提示
使用 GROUP BY 时,QO 可在哈希聚合与流聚合之间选择。若输入已排序,可强制流聚合;若希望始终哈希聚合,则:
-
强制流聚合
sqlSELECT OrderID, AVG(Quantity) FROM Sales.OrderLines GROUP BY OrderID OPTION (ORDER GROUP); -
强制哈希聚合
sqlSELECT OrderID, AVG(Quantity) FROM Sales.OrderLines GROUP BY OrderID OPTION (HASH GROUP);
节85.3:FAST n 行提示
指示优化器优先快速返回前 n 行,之后再继续生成完整结果集:
sql
SELECT OrderID, AVG(Quantity)
FROM Sales.OrderLines
GROUP BY OrderID
OPTION (FAST 20);
节85.4:UNION 提示
当使用 UNION 时,QO 可在合并、串联、哈希匹配三种算法间选择,可强制其一:
sql
SELECT OrderID, OrderDate, ExpectedDeliveryDate, Comments
FROM Sales.Orders
WHERE OrderDate > DATEADD(day, -1, GETDATE())
UNION
SELECT PurchaseOrderID AS OrderID, OrderDate, ExpectedDeliveryDate, Comments
FROM Purchasing.PurchaseOrders
WHERE OrderDate > DATEADD(day, -1, GETDATE())
OPTION (HASH UNION); -- 或 CONCAT UNION / MERGE UNION
节85.5:MAXDOP 选项
为当前查询指定最大并行度,覆盖 sp_configure 与资源调控器的设置:
sql
SELECT OrderID, AVG(Quantity)
FROM Sales.OrderLines
GROUP BY OrderID
OPTION (MAXDOP 2);
设为 0 时,由服务器自行决定并行度。
节85.6:索引提示
强制查询使用指定索引,而非让优化器自行选择。当统计信息缺失或过时,或你有特殊需求时可用:
sql
SELECT *
FROM mytable WITH (INDEX (ix_date))
WHERE field1 > 0
AND CreationDate > '20170101';