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;