更新时间:2024-04-28 GMT+08:00

配置参数的hint

功能描述

指明计划生成时配置参数的值,又称作guc hint。

语法格式

set [global](guc_name guc_value)

参数说明

  • global表示hint设置的配置参数在语句级别生效,不加global表示hint设置的配置参数在子查询级别生效,即仅在hint所在的子查询中生效,在该语句的其它子查询中不生效。
  • guc_name表示hint指定的配置参数的名称。
  • guc_value表示hint指定的配置参数的值。
  • 如果hint设置的配置参数在语句级别生效,则该hint必须写在顶层查询中,而不能写在子查询中。对于UNION、INTERSECT、EXCEPT和MINUS语句,可以将在语句级别的guc hint写在参与集合运算的任意一个SELECT子句上,该guc hint设置的配置参数会在参与集合运算的每个SELECT子句上生效。
  • 子查询提升时,该子查询上的所有guc hint会被丢弃。
  • 如果一个配置参数既被语句级别的guc hint设置,又被子查询级别的guc hint设置,则子查询级别的guc hint在对应的子查询中生效,语句级别的guc hint在语句的其它子查询中生效。

guc hint当前仅支持部分配置参数,并且有些配置参数不支持在子查询级别设置,只能在语句级别设置,以下为支持的参数列表:

表1 guc hint支持的配置参数

配置参数名

是否支持在子查询级别设置

agg_max_mem

agg_redistribute_enhancement

best_agg_plan

cost_model_version

cost_param

enable_bitmapscan

enable_broadcast

enable_redistribute

enable_extrapolation_stats

enable_fast_query_shipping

enable_force_vector_engine

enable_hashagg

enable_hashjoin

enable_index_nestloop

enable_indexscan

enable_join_pseudoconst

enable_nestloop

enable_nodegroup_debug

enable_partition_dynamic_pruning

enable_sort

enable_stream_ctescan

enable_value_redistribute

enable_vector_engine

expected_computing_nodegroup

force_bitmapand

from_collapse_limit

join_collapse_limit

join_num_distinct

outer_join_max_rows_multipler

prefer_hashjoin_path

qrw_inlist2join_optmode

qual_num_distinct

query_dop

query_max_mem

query_mem

rewrite_rule

setop_optmode

skew_option

index_selectivity_cost

index_cost_limit

enable_accelerate_select

示例

示例中原语句使用如下hint:

explain
select /*+ set global(query_dop 0) */ i_product_name product_name
...

该hint表示:在整个语句的计划生成过程中,将配置参数query_dop设置为0,即打开SMP自适应功能。生成的计划如下图所示: