后浪云OceanBase教程:OceanBase 与查询转换相关的 Hint

NO_REWRITE Hint

NO_REWRITE​ Hint 指示优化器为禁用查询去重写查询块,并覆盖了参数 ​QUERY_REWRITE_ENABLED​ 的设置。

以下是 ​NO_REWRITE​ 的语法:


/*+ NO_REWRITE [ ( @ queryblock ) ] */

示例如下:


SELECT /*+ NO_REWRITE */ sum(s.amount_sold) AS dollars
  FROM sales s, times t
  WHERE s.time_id = t.time_id
  GROUP BY t.calendar_month_desc;

NO_EXPAND Hint

NO_EXPAND​ Hint 指示优化器不要对 ​WHERE​ 子句中具有 ​OR​ 条件或 ​IN​ 列表的查询考虑 ​OR​ 扩展。 通常,优化器会使用 ​OR​ 扩展,当确定使用 ​OR​ 扩展的成本低于不使用它时。

以下是 ​NO_EXPAND​ Hint 的语法:


/*+ NO_EXPAND [ ( @ queryblock ) ] */

示例如下:


SELECT /*+ NO_EXPAND */ *
  FROM employees e, departments d
  WHERE e.manager_id = 108
     OR d.department_id = 110;

USE_CONCAT Hint

USE_CONCAT​ Hint 指示优化器使用 ​UNION ALL​ 运算符将查询 ​WHERE​ 子句中的组合 ​OR​ 条件转换为复合查询。 如果没有这个 Hint,则仅当使用串联查询的成本低于比没有串联查询的成本时,才会发生此转换。​USE_CONCAT​ Hint 将覆盖成本注意事项。

以下是 ​USE_CONCAT​ Hint 的语法:


/*+ USE_CONCAT [ ( @ queryblock ) ] */

示例如下:


SELECT /*+ USE_CONCAT */ *
  FROM employees e
  WHERE manager_id = 108
     OR department_id = 110;

MERGE Hint

MERGE​ Hint 使您可以在查询中合并视图。

以下是 ​MERGE​ Hint 的语法:


/*+ MERGE [ ( @ queryblock )  | ( [ @ queryblock ] tablespec ) ] */

如果视图的查询块在 ​SELECT​ 列表中包含 ​GROUP B​Y 子句或 ​DISTINCT​ 运算符时,只有启用了复杂的视图合并后,优化器才能将视图合并到正在访问的语句中。 如果子查询不相关,则也可以使用复杂合并将 ​IN​ 子查询合并到访问语句中。

示例如下:


SELECT /*+ MERGE(v) */ e1.last_name, e1.salary, v.avg_salary
   FROM employees e1,
        (SELECT department_id, avg(salary) avg_salary 
           FROM employees e2
           GROUP BY department_id) v 
   WHERE e1.department_id = v.department_id
     AND e1.salary > v.avg_salary
   ORDER BY e1.last_name;

当不带参数使用 ​MERGE​ Hint 时,应将其放在视图查询块中。 当视图名称作为参数使用

MERGE​ Hint 时,应将其放在周边查询中。

NO_MERGE Hint

NO_MERGE​ Hint 指示优化器不要将外部查询和任何内联视图查询合并到单个查询中。

以下是 ​NO_MERGE​ Hint 的语法:


/*+ NO_MERGE [ ( @ queryblock )  | ( [ @ queryblock ] tablespec ) ] */

此 Hint 会影响您访问视图的方式。 例如,以下语句导致视图 seattle_dept 不被合并:


SELECT /*+ NO_MERGE(seattle_dept) */ e1.last_name, seattle_dept.department_name
  FROM employees e1,
       (SELECT location_id, department_id, department_name
          FROM departments
          WHERE location_id = 1700) seattle_dept
  WHERE e1.department_id = seattle_dept.department_id;

在视图查询块中使用 ​NO_MERGE​ Hint 时,不需要为它指定参数。 在周围的查询中使用 ​NO_MERGE​ Hint 时,需要将视图名称指定为它的参数。

UNNEST Hint

UNNEST​ Hint 指示优化器不要嵌套而是并将子查询的主体合并到包含该 Hint 的查询块的主体中,从而使优化器在评估访问路径和联接时将它们一起考虑在内。

以下是 ​UNNEST​ Hint 的语法:


/*+ UNNEST [ ( @ queryblock ) ] */

在取消嵌套子查询之前,优化器首先验证子查询是否有效,并且必须通过探索和查询优化测试。 使用 ​UNNEST​ Hint 时优化器仅检查子查询块的有效性。 如果子查询块有效,那么将直接取消嵌套子查询,而无需通过探索和查询优化测试。

示例如下:


SELECT AVG(t1.c) FROM t1 
WHERE t1.b >= 
    (SELECT /*+unnest*/AVG(t2.b) 
     FROM t2
     WHERE t1.a = t2.a);

NO_UNNEST Hint

NO_UNNEST​ Hint 用来关闭取消嵌套的操作。

以下是 ​NO_UNNEST​ Hint 的语法:


/*+ NO_UNNEST [ ( @ queryblock ) ] */

示例如下:


SELECT /*+no_unnest(@qb1)*/AVG(t1.c) 
FROM t1 WHERE t1.b >= 
    (SELECT /*+qb_name(qb1)*/AVG(t2.b) 
     FROM t2) 
     WHERE t1.a = t2.a);

PLACE_GROUP_BY Hint

PLACE_GROUP_BY​ Hint指示优化器采用 GROUP BY 位置替换规则,此时优化器不考虑转换之后的代价增大。

以下是​ PLACE_GROUP_BY​ Hint的语法:


/*+ PLACE_GROUP_BY [ ( @ queryblock ) ] */

示例如下:


SELECT /*+place_group_by*/SUM(t1.c),SUM(t2.c) FROM t1, t2
WHERE t1.a = t2.a AND t1.b > 10 AND t2.b > 10
GROUP BY  t1.a;

NO_PLACE_GROUP_BY Hint

NO_PLACE_GROUP_BY​ Hint 用来关闭 GROUP BY 位置替换转换。

以下是 ​NO_PLACE_GROUP_BY​ Hint的语法:


/*+ NO_PLACE_GROUP_BY [ ( @ queryblock ) ] */

示例如下:


SELECT /*+no_place_group_by*/SUM(t1.c),SUM(t2.c) FROM t1, t2
WHERE t1.a = t2.a AND t1.b > 10 AND t2.b > 10
GROUP BY  t1.a;

NO_PRED_DEDUCE Hint

NO_PRED_DEDUCE​ Hint 用来指示优化器不是用谓词推导转换规则。

以下是 ​NO_PRED_DEDUCE​ Hint的语法:


/*+ NO_PRED_DEDUCE [ ( @ queryblock ) ] */

示例如下:


SELECT /*+no_pred_deduce(@qb1)*/ * 
FROM  (
  SELECT /*+no_merge qb_name(qb1)*/ t1.a, t2.b 
  FROM t1, t2 
  WHERE t1.a = t2.a) v, t3 
WHERE t3.a = 1 AND t3.a = v.a;

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/294115.html<

(0)
运维的头像运维
上一篇2025-05-20 22:34
下一篇 2025-05-20 22:35

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注