SQL Server笔记 -- 第85章:查询提示

节85.1:联接提示

当两表联接时,查询优化器(QO)可在哈希、循环、合并三种联接算法间选择。若你确信已知最优算法,可强制指定:

  • 内层循环联接

    sql 复制代码
    SELECT TOP 100 *
    FROM Sales.Orders o
    INNER LOOP JOIN Sales.OrderLines ol
        ON o.OrderID = ol.OrderID;
  • 内层合并联接

    sql 复制代码
    SELECT TOP 100 *
    FROM Sales.Orders o
    INNER MERGE JOIN Sales.OrderLines ol
        ON o.OrderID = ol.OrderID;
  • 内层哈希联接

    sql 复制代码
    SELECT TOP 100 *
    FROM Sales.Orders o
    INNER HASH JOIN Sales.OrderLines ol
        ON o.OrderID = ol.OrderID;

节85.2:GROUP BY 提示

使用 GROUP BY 时,QO 可在哈希聚合与流聚合之间选择。若输入已排序,可强制流聚合;若希望始终哈希聚合,则:

  • 强制流聚合

    sql 复制代码
    SELECT OrderID, AVG(Quantity)
    FROM Sales.OrderLines
    GROUP BY OrderID
    OPTION (ORDER GROUP);
  • 强制哈希聚合

    sql 复制代码
    SELECT 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';
相关推荐
小则又沐风a4 分钟前
类和对象----最终篇
java·前端·数据库
liliangcsdn6 分钟前
LLM如何以ReAct Agent方式统计分析去重后数据
数据库·人工智能·全文检索
问道飞鱼10 分钟前
【数据库相关】MySQL全分类SQL详解(超多数据类型+全约束+实战落地)
数据库·sql·mysql·范例
不剪发的Tony老师12 分钟前
mayfly-go:一款基于WEB的服务器、数据库、中间件统一运维平台
运维·服务器·数据库
Evand J12 分钟前
PSINS工具箱笔记——SINS/GNSS的例程
笔记·gnss·组合导航·工具箱·psins·导航工具箱·sins
minji...18 分钟前
Linux 多线程(五)用C++语言以面向对象方式封装线程
linux·运维·服务器·网络·jvm·数据库
喵叔哟20 分钟前
31_Document处理通用Skill:多格式抽取+结构化输出+校验层
数据库
搜佛说25 分钟前
03-第3章-基础CRUD操作
数据库·物联网·边缘计算·iot·嵌入式实时数据库
宵时待雨31 分钟前
linux笔记归纳1:linux初识
linux·运维·笔记
Keep Running *34 分钟前
Docker_学习笔记
笔记·学习·docker