网络
虚拟私有云 VPC
弹性公网IP EIP
弹性负载均衡 ELB
NAT网关 NAT
云专线 DC
虚拟专用网络 VPN
云连接 CC
VPC终端节点 VPCEP
企业路由器 ER
企业交换机 ESW
全球加速 GA
企业连接 EC
云原生应用网络 ANC
安全与合规
安全技术与应用
Web应用防火墙 WAF
企业主机安全 HSS
云防火墙 CFW
安全云脑 SecMaster
DDoS防护 AAD
数据加密服务 DEW
数据库安全服务 DBSS
云堡垒机 CBH
数据安全中心 DSC
云证书管理服务 CCM
威胁检测服务 MTD
态势感知 SA
认证测试中心 CTC
边缘安全 EdgeSec
应用中间件
微服务引擎 CSE
分布式消息服务Kafka版
分布式消息服务RabbitMQ版
分布式消息服务RocketMQ版
API网关 APIG
分布式缓存服务 DCS
多活高可用服务 MAS
事件网格 EG
管理与监管
统一身份认证服务 IAM
消息通知服务 SMN
云监控服务 CES
应用运维管理 AOM
应用性能管理 APM
云日志服务 LTS
云审计服务 CTS
标签管理服务 TMS
配置审计 Config
应用身份管理服务 OneAccess
资源访问管理 RAM
组织 Organizations
资源编排服务 RFS
优化顾问 OA
IAM 身份中心
云运维中心 COC
资源治理中心 RGC
解决方案
高性能计算 HPC
SAP
混合云灾备
开天工业工作台 MIW
Haydn解决方案工厂
数字化诊断治理专家服务
云生态
云商店
合作伙伴中心
华为云开发者学堂
华为云慧通差旅
开发与运维
软件开发生产线 CodeArts
需求管理 CodeArts Req
流水线 CodeArts Pipeline
代码检查 CodeArts Check
编译构建 CodeArts Build
部署 CodeArts Deploy
测试计划 CodeArts TestPlan
制品仓库 CodeArts Artifact
移动应用测试 MobileAPPTest
CodeArts IDE Online
开源镜像站 Mirrors
性能测试 CodeArts PerfTest
应用管理与运维平台 ServiceStage
云应用引擎 CAE
开源治理服务 CodeArts Governance
华为云Astro轻应用
CodeArts IDE
Astro工作流 AstroFlow
代码托管 CodeArts Repo
漏洞管理服务 CodeArts Inspector
联接 CodeArtsLink
软件建模 CodeArts Modeling
Astro企业应用 AstroPro
CodeArts盘古助手
华为云Astro大屏应用
计算
弹性云服务器 ECS
Flexus云服务
裸金属服务器 BMS
云手机服务器 CPH
专属主机 DeH
弹性伸缩 AS
镜像服务 IMS
函数工作流 FunctionGraph
云耀云服务器(旧版)
VR云渲游平台 CVR
Huawei Cloud EulerOS
云化数据中心 CloudDC
网络
虚拟私有云 VPC
弹性公网IP EIP
弹性负载均衡 ELB
NAT网关 NAT
云专线 DC
虚拟专用网络 VPN
云连接 CC
VPC终端节点 VPCEP
企业路由器 ER
企业交换机 ESW
全球加速 GA
企业连接 EC
云原生应用网络 ANC
CDN与智能边缘
内容分发网络 CDN
智能边缘云 IEC
智能边缘平台 IEF
CloudPond云服务
安全与合规
安全技术与应用
Web应用防火墙 WAF
企业主机安全 HSS
云防火墙 CFW
安全云脑 SecMaster
DDoS防护 AAD
数据加密服务 DEW
数据库安全服务 DBSS
云堡垒机 CBH
数据安全中心 DSC
云证书管理服务 CCM
威胁检测服务 MTD
态势感知 SA
认证测试中心 CTC
边缘安全 EdgeSec
大数据
MapReduce服务 MRS
数据湖探索 DLI
表格存储服务 CloudTable
可信智能计算服务 TICS
推荐系统 RES
云搜索服务 CSS
数据可视化 DLV
数据接入服务 DIS
数据仓库服务 GaussDB(DWS)
数据治理中心 DataArts Studio
湖仓构建 LakeFormation
智能数据洞察 DataArts Insight
应用中间件
微服务引擎 CSE
分布式消息服务Kafka版
分布式消息服务RabbitMQ版
分布式消息服务RocketMQ版
API网关 APIG
分布式缓存服务 DCS
多活高可用服务 MAS
事件网格 EG
开天aPaaS
应用平台 AppStage
开天企业工作台 MSSE
开天集成工作台 MSSI
API中心 API Hub
云消息服务 KooMessage
交换数据空间 EDS
云地图服务 KooMap
云手机服务 KooPhone
组织成员账号 OrgID
云空间服务 KooDrive
管理与监管
统一身份认证服务 IAM
消息通知服务 SMN
云监控服务 CES
应用运维管理 AOM
应用性能管理 APM
云日志服务 LTS
云审计服务 CTS
标签管理服务 TMS
配置审计 Config
应用身份管理服务 OneAccess
资源访问管理 RAM
组织 Organizations
资源编排服务 RFS
优化顾问 OA
IAM 身份中心
云运维中心 COC
资源治理中心 RGC
区块链
区块链服务 BCS
数字资产链 DAC
华为云区块链引擎服务 HBS
解决方案
高性能计算 HPC
SAP
混合云灾备
开天工业工作台 MIW
Haydn解决方案工厂
数字化诊断治理专家服务
价格
成本优化最佳实践
专属云商业逻辑
云生态
云商店
合作伙伴中心
华为云开发者学堂
华为云慧通差旅
其他
管理控制台
消息中心
产品价格详情
系统权限
客户关联华为云合作伙伴须知
公共问题
宽限期保留期
奖励推广计划
活动
云服务信任体系能力说明
开发与运维
软件开发生产线 CodeArts
需求管理 CodeArts Req
流水线 CodeArts Pipeline
代码检查 CodeArts Check
编译构建 CodeArts Build
部署 CodeArts Deploy
测试计划 CodeArts TestPlan
制品仓库 CodeArts Artifact
移动应用测试 MobileAPPTest
CodeArts IDE Online
开源镜像站 Mirrors
性能测试 CodeArts PerfTest
应用管理与运维平台 ServiceStage
云应用引擎 CAE
开源治理服务 CodeArts Governance
华为云Astro轻应用
CodeArts IDE
Astro工作流 AstroFlow
代码托管 CodeArts Repo
漏洞管理服务 CodeArts Inspector
联接 CodeArtsLink
软件建模 CodeArts Modeling
Astro企业应用 AstroPro
CodeArts盘古助手
华为云Astro大屏应用
存储
对象存储服务 OBS
云硬盘 EVS
云备份 CBR
高性能弹性文件服务 SFS Turbo
弹性文件服务 SFS
存储容灾服务 SDRS
云硬盘备份 VBS
云服务器备份 CSBS
数据快递服务 DES
云存储网关 CSG
专属分布式存储服务 DSS
数据工坊 DWR
地图数据 MapDS
键值存储服务 KVS
容器
云容器引擎 CCE
云容器实例 CCI
容器镜像服务 SWR
云原生服务中心 OSC
应用服务网格 ASM
华为云UCS
数据库
云数据库 RDS
数据复制服务 DRS
文档数据库服务 DDS
分布式数据库中间件 DDM
云数据库 GaussDB
云数据库 GeminiDB
数据管理服务 DAS
数据库和应用迁移 UGO
云数据库 TaurusDB
人工智能
AI开发平台ModelArts
华为HiLens
图引擎服务 GES
图像识别 Image
文字识别 OCR
自然语言处理 NLP
内容审核 Moderation
图像搜索 ImageSearch
医疗智能体 EIHealth
企业级AI应用开发专业套件 ModelArts Pro
人脸识别服务 FRS
对话机器人服务 CBS
语音交互服务 SIS
人证核身服务 IVS
视频智能分析服务 VIAS
城市智能体
自动驾驶云服务 Octopus
盘古大模型 PanguLargeModels
IoT物联网
设备接入 IoTDA
全球SIM联接 GSL
IoT数据分析 IoTA
路网数字化服务 DRIS
IoT边缘 IoTEdge
设备发放 IoTDP
企业应用
域名注册服务 Domains
云解析服务 DNS
企业门户 EWP
ICP备案
商标注册
华为云WeLink
华为云会议 Meeting
隐私保护通话 PrivateNumber
语音通话 VoiceCall
消息&短信 MSGSMS
云管理网络
SD-WAN 云服务
边缘数据中心管理 EDCM
云桌面 Workspace
应用与数据集成平台 ROMA Connect
ROMA资产中心 ROMA Exchange
API全生命周期管理 ROMA API
政企自服务管理 ESM
视频
实时音视频 SparkRTC
视频直播 Live
视频点播 VOD
媒体处理 MPC
视频接入服务 VIS
数字内容生产线 MetaStudio
迁移
主机迁移服务 SMS
对象存储迁移服务 OMS
云数据迁移 CDM
迁移中心 MGC
专属云
专属计算集群 DCC
开发者工具
SDK开发指南
API签名指南
DevStar
华为云命令行工具服务 KooCLI
Huawei Cloud Toolkit
CodeArts API
云化转型
云架构中心
云采用框架
用户服务
账号中心
费用中心
成本中心
资源中心
企业管理
工单管理
客户运营能力
国际站常见问题
支持计划
专业服务
合作伙伴支持计划
我的凭证
华为云公共事业服务云平台
工业软件
工业数字模型驱动引擎
硬件开发工具链平台云服务
工业数据转换引擎云服务

优化器方法配置

更新时间:2024-11-12 GMT+08:00
分享

这些配置参数提供了影响查询优化器选择查询规划的原始方法。如果优化器为特定的查询选择的缺省规划并不是最优的,可以通过使用这些配置参数强制优化器选择一个不同的规划来临时解决这个问题。更好的方法包括调节优化器开销常量、手动运行ANALYZE、增加配置参数default_statistics_target的值、增加使用ALTER TABLE SET STATISTICS为指定列增加收集的统计信息。

enable_bitmapscan

参数说明控制优化器对位图扫描规划类型的使用。

参数类型:布尔型

参数单位:

取值范围

  • on:表示使用。
  • off:表示不使用。

默认值on

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:关闭后会全局禁止bitmap scan算子,可能导致部分场景性能下降。若要更改,请谨慎操作,避免因误操作产生意料之外的风险。

force_bitmapand

参数说明控制优化器对bitmap and规划类型的强制使用。

参数类型:布尔型

参数单位:

取值范围

  • on:表示使用。
  • off:表示不使用。

默认值off

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:打开该参数后当满足bitmap and索引扫描算子使用条件时,优化器生成计划会强制走bitmap and索引扫描,部分场景下可能影响查询性能。若要更改,请谨慎操作,避免因误操作产生意料之外的风险。

enable_hashagg

参数说明控制优化器对Hash聚集规划类型的使用。

参数类型:布尔型

参数单位:

取值范围

  • on:表示使用。
  • off:表示不使用。

默认值on

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:关闭后会导致部分场景下Hash聚集算子无法使用,影响查询改写逻辑,使查询性能下降。若要更改,请谨慎操作,避免因误操作产生意料之外的风险。

enable_hashjoin

参数说明控制优化器对Hash连接规划类型的使用。

参数类型:布尔型

参数单位:

取值范围

  • on:表示使用。
  • off:表示不使用。

默认值on

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:关闭后会全局禁止使用Hash Join算子,优先生成其他Join类型计划,可能导致部分场景性能下降。若要更改,请谨慎操作,避免因误操作产生意料之外的风险。

enable_indexscan

参数说明控制优化器对索引扫描规划类型的使用。

参数类型:布尔型

参数单位:

取值范围

  • on:表示使用。
  • off:表示不使用。

默认值on

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:关闭后会全局禁止使用索引扫描算子,可能导致部分场景性能下降。若要更改,请谨慎操作,避免因误操作产生意料之外的风险。

enable_indexonlyscan

参数说明控制优化器对仅索引扫描规划类型的使用。

参数类型:布尔型

参数单位:

取值范围

  • on:表示使用。
  • off:表示不使用。

默认值on

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:关闭后会全局禁止使用仅索引扫描算子,一些仅需要走索引扫描不需要回表的计划将无法生成,可能导致部分场景性能下降。若要更改,请谨慎操作,避免因误操作产生意料之外的风险。

enable_gsiscan

参数说明控制优化器对仅全局二级索引扫描规划类型的使用。

参数类型:布尔型

参数单位:

取值范围

  • on:表示使用。
  • off:表示不使用。

默认值on

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:在有全局二级索引的场景下,如果关闭该参数,会导致无法生成仅全局二级索引扫描计划,可能影响查询性能。

enable_gsitablescan

参数说明控制优化器对全局二级索引回表扫描规划类型的使用。

参数类型:布尔型

参数单位:

取值范围

  • on:表示使用。
  • off:表示不使用。

默认值on

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:在有全局二级索引的场景下,如果关闭该参数,会导致无法生成全局二级索引回表扫描计划,可能影响查询性能。

gsi_fastpath_level

参数说明控制优化器是否执行全局二级索引简单查询的规则判断系统,全局二级索引的简单查询规则如下:
  • 单个表、没有子查询、没有子链接、目标表不是视图。
  • 查询语句无法生成普通索引的执行计划。
  • 查询语句无法生成GSI的IndexOnlyScan执行计划。
  • 查询语句不包含Scan类的Hint,如TableScan、IndexScan等。
  • WHERE条件中包含等值条件且等值条件包含候选GSI(唯一且不是部分GSI索引)的索引键。

参数类型:枚举类型

参数单位:

取值范围

  • strict:等值条件包含GSI所有索引键。
  • partial:等值条件包含GSI的部分索引键(最左匹配),性能不一定最优。
  • none:关闭。

默认值strict

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:设置不当可能影响部分GSI场景下的计划生成,影响查询性能。

说明:
  • partial的使用参考如下场景:
    gaussdb=# CREATE TABLE t1(a INT, b INT, c INT);
    gaussdb=# CREATE GLOBAL UNIQUE INDEX t1_gsi ON t1(b,c);
    -- Q1
    gaussdb=# SELECT * FROM t1 WHERE b=1;
    -- Q2
    gaussdb=# SELECT * FROM t1 WHERE b=1 LIMIT 1;

    上述场景中,GSI索引建在(b,c)两列上,gsi_fastpath_level参数设置为partial时,查询语句Q1和Q2才可以生成GSI非Stream回表计划。索引唯一性由(b,c)两列保证,对于查询语句Q1,返回结果可能有多条,GSI非Stream回表计划的性能不一定是最优的,对于查询语句Q2,由于包含limit 1的条件,GSI非Stream回表计划的性能依然是最优的。

enable_material

参数说明控制优化器对实体化的使用。消除整个实体化是不可能的,但是可以关闭这个参数以防止优化器插入实体节点。

参数类型:布尔型

参数单位:

取值范围

  • on:表示使用。
  • off:表示不使用。

默认值on

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:关闭后会禁止优化器插入实体节点,部分场景下无法生成Material算子,可能导致部分场景性能下降。

enable_mergejoin

参数说明控制优化器对融合连接规划类型的使用。

参数类型:布尔型

参数单位:

取值范围

  • on:表示使用。
  • off:表示不使用。

默认值off

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:打开该参数优化器会对满足条件的Join连接生成融合连接路径,可能导致该场景下选择的连接算子非实际最优。

enable_nestloop

参数说明控制优化器对内表全表扫描嵌套循环连接规划类型的使用。完全消除嵌套循环连接是不可能的,但是,若关闭这个参数,当存在其他方法时,优化器会优先选择其他方法。

参数类型:布尔型

参数单位:

取值范围

  • on:表示使用。
  • off:表示不使用。

默认值off

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:打开该参数优化器会对满足条件的Join连接生成NestloopJoin路径,可能导致该场景下选择的连接算子非实际最优。

enable_index_nestloop

参数说明控制优化器对内表参数化索引扫描嵌套循环连接规划类型的使用。

参数类型:布尔型

参数单位:

取值范围

  • on:表示使用。
  • off:表示不使用。

默认值on

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:关闭该参数会导致部分场景下无法生成参数化路径,通常参数化路径可以提升查询性能,因此一般建议开启。

enable_remote_param

参数说明控制XC参数化路径特性的打开与关闭,打开后能够生成XC参数化路径计划。

参数类型:布尔型

参数单位:

取值范围

  • on:表示使用。
  • off:表示不使用。

默认值off

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:在相关子链接和Nestloop场景中,如果外表规模较小且内表规模较大,并且内表在关联条件上有能够最左匹配的索引时,设置为on,能够提高性能。

设置不当的风险与影响:在相关子链接和Nestloop场景中,如果外表规模较大且内表规模较小,设置为on,可能会导致性能变差。

须知:
  • 仅支持XC计划,不支持Stream和FQS计划。
  • 当且仅当基表生成索引参数化路径时,才对基表生成带参数rescan的计划。
  • 仅支持基础表的参数化路径,不支持join表的参数化路径。
  • 不支持Stream和XC计划自适应选择。
  • Nestloop参数化路径仅支持内表为RemoteQuery的场景。
  • 不支持predpush Hint。
  • 不支持带PBE参数的RemoteQuery下推。
  • 在部分场景参数化路径场景执行性能无明显优势,需要人工调优。
  • M-Compatibility模式数据库下,不支持max_datanode_for_plan参数大于0时显示DN计划。

enable_seqscan

参数说明控制优化器对顺序扫描规划类型的使用。完全消除顺序扫描是不可能的,但是,若关闭这个参数,当存在其他方法时,优化器会优先选择其他方法。

参数类型:布尔型

参数单位:

取值范围

  • on:表示使用。
  • off:表示不使用。

默认值on

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:关闭该参数会导致优化器倾向于选择其他扫描方法,降低顺序扫描方法的优先级,部分场景下可能会影响查询性能。

enable_sort

参数说明控制优化器使用的排序步骤。完全消除明确的排序是不可能的,但是,若关闭这个参数,当存在其他方法时,优化器会优先选择其他方法。

参数类型:布尔型

参数单位:

取值范围

  • on:表示使用。
  • off:表示不使用。

默认值on

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:关闭该参数会导致优化器倾向于选择其他方法,降低排序方法使用的优先级,产生的不良影响较小,通常建议打开。

enable_tidscan

参数说明控制优化器对TID扫描规划类型的使用。

参数类型:布尔型

参数单位:

取值范围

  • on:表示使用。
  • off:表示不使用。

默认值on

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:关闭该参数会导致优化器倾向于选择其他方法,降低TID扫描方法使用的优先级,产生的不良影响较小,通常建议打开。

enable_kill_query

参数说明CASCADE模式删除用户时,会删除此用户拥有的所有对象。此参数标识在删除用户的时候,是否允许取消锁定此用户所属对象的query。

参数类型:布尔型

参数单位:

取值范围

  • on:表示允许取消锁定。
  • off:表示不允许取消锁定。

默认值off

设置方式:该参数属于SUSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:打开后,用户被删除时,该用户对应query可能会暴露,对系统的一致性和安全性带来不利影响。

enable_stream_concurrent_update

参数说明控制优化器在并发更新场景下对stream的使用,该参数受限于enable_stream_operator参数。如果出现并发update冲突,有一定可能会出现报错,可以通过本参数控制。

参数类型:布尔型

参数单位:

取值范围

  • on:表示允许优化器对update语句生成stream计划。
  • off:表示优化器对update语句仅能生成非stream计划。

默认值on

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:关闭该参数会导致优化器倾向于选择其他方法,对update语句仅能生成非stream计划,产生的不良影响较小,通常建议打开。

enable_stream_operator

参数说明控制优化器对stream的使用。当enable_stream_operator参数关闭时,会有大量关于计划不能下推的日志记录到日志文件中。如果用户不需要这些日志内容,建议用户在enable_stream_operator参数关闭时,也同时关闭enable_unshipping_log参数。

参数类型:布尔型

参数单位:

取值范围

  • on:表示使用。
  • off:表示不使用。
默认值
  • 独立部署:off

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:关闭该参数优化器将无法生成Stream计划,可能导致查询性能下降。

enable_stream_recursive

参数说明控制是否将with recursive关联查询下推DN分布式执行。

参数类型:布尔型

参数单位:

取值范围

  • on:表示支持使用with recursive关联查询下推DN分布式执行。
  • off:表示不支持使用with recursive下推。

默认值on

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:关闭可能会导致查询性能下降。

max_recursive_times

参数说明控制with recursive的最大迭代次数。

参数类型:整型

参数单位:

取值范围0 ~ 2147483647

默认值200

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐根据实际业务评估合理值。

设置不当的风险与影响:对于with recursive语句,此参数用于避免陷入死循环,层次查询可用nocycle跳出循环。若要更改,请在理解参数含义后谨慎操作,避免因误操作产生意料之外的风险。

enforce_a_behavior

参数说明:控制正则表达式的规则匹配模式。

参数类型:布尔型

参数单位:

取值范围:

  • on:表示正则表达式采用A格式的匹配规则。
  • off:表示正则表达式采用POSIX格式的匹配规则。

默认值:on

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:根据业务场景进行设置。

设置不当的风险与影响:查询语句中正则表达式无法按预期匹配。

enable_vector_engine

参数说明控制优化器对向量化执行引擎的使用。

参数类型:布尔型

参数单位:

取值范围

  • on:表示使用。
  • off:表示不使用。

默认值on

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:关闭可能会导致优化器未能针对特定场景生成向量化的查询计划,从而影响查询性能。

enable_broadcast

参数说明控制优化器在stream代价估算时对broadcast分布方式的使用。

参数类型:布尔型

参数单位:

取值范围

  • on:表示使用。
  • off:表示不使用。

默认值on

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:设置不当可能会影响stream计划生成的准确性,从而影响查询性能。

enable_change_hjcost

参数说明控制优化器在Hash Join代价估算路径选择时,是否使用将内表运行时代价排除在Hash Join节点运行时代价外的估算方式。如果使用,则有利于选择条数少,但运行代价大的表做内表。

参数类型:布尔型

参数单位:

取值范围

  • on:表示使用。
  • off:表示不使用。

默认值off

设置方式:该参数属于SUSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:设置不当可能会导致Hash Join代价估算有误,从而影响带有Hash Join计划生成的准确性。

best_agg_plan

参数说明本参数用于控制优化器生成哪种hashagg的计划。对于stream下的Agg操作,优化器会生成三种计划:
  1. hashagg+gather(redistribute)+hashagg。
  2. redistribute+hashagg(+gather)。
  3. hashagg+redistribute+hashagg(+gather)。

参数类型:整型

参数单位:

取值范围0 ~ 3

  • 0:优化器会根据以上三种计划的估算cost选择最优的一种计划生成。
  • 1:强制生成第一种计划。
  • 2:如果group by列可以重分布,强制生成第二种计划,否则生成第一种计划。
  • 3:如果group by列可以重分布,强制生成第三种计划,否则生成第一种计划。

默认值0

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:该参数会影响hashagg的生成方式,通常建议使用默认值,设置其他值会倾向于某一类hashagg,设置不当可能会影响部分场景下查询的性能。

agg_redistribute_enhancement

参数说明进行Agg操作时,如果包含多个group by列且均不为分布列,进行重分布时会选择某一group by列进行重分布。本参数控制选择重分布列的策略。

参数类型:布尔型

参数单位:

取值范围

  • on:表示会选择估算distinct值最多的一个可重分布列作为重分布列。
  • off:表示会选择第一个可重分布列作为重分布列。

默认值off

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:打开会增加计划生成时间,但可能会选择更合理的重分布列。

enable_absolute_tablespace

参数说明:控制表空间是否可以使用绝对路径。

参数类型:布尔型

参数单位:

取值范围:

  • on:表示可以使用绝对路径。
  • off:表示不可以使用绝对路径。

默认值:on

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:关闭该参数创建表空间时将不允许使用绝对路径,建议根据业务实际需要设置,无其他风险。

enable_valuepartition_pruning

参数说明:是否对DFS分区表进行静态/动态优化。

参数类型:布尔型

参数单位:

取值范围:

  • on:表示对DFS分区表进行静态/动态优化。
  • off:表示不对DFS分区表进行静态/动态优化。

默认值:on

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:关闭后DFS分区表相关查询性能可能下降。

expected_computing_nodegroup

参数说明标识选定的计算Node Group模式或目标计算Node Group。Node Group目前为内部机制,用户无需设置。共四种计算Node Group模式,用于关联操作和聚集操作时选定计算Node Group。在每一种模式中,优化器有针对性地选定几个候选计算Node Group,然后根据代价,从中为当前算子挑选最佳计算Node Group。

参数类型:字符串

参数单位:

取值范围

  • optimal:候选计算Node Group列表包含算子操作对象所在的Node Group和由当前用户具有COMPUTE权限的所有Node Group包含的所有DN构成的Node Group。
  • query:候选计算Node Group列表包含算子操作对象所在的Node Group和由当前查询涉及的所有基表所在Node Group包含的所有DN构成的Node Group。
  • Node Group名(enable_nodegroup_debug被设置为off):候选计算Node Group列表包含算子操作对象所在的Node Group和该指定的Node Group。
  • Node Group名(enable_nodegroup_debug被设置为on):候选计算Node Group为指定的Node Group。

默认值query

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:设置不当可能会导致优化器不能选择更优的计算Node Group,从而影响查询性能。

enable_nodegroup_debug

参数说明控制优化器在多Node Group环境下,是否使用强制弹性计算。Node Group目前为内部机制,用户无需设置。该参数只在expected_computing_nodegroup被设置为具体Node Group时生效。

参数类型:布尔型

参数单位:

取值范围

  • on:表示强制将计算弹性到expected_computing_nodegroup所指定的Node Group进行计算。
  • off:表示不强制使用某个Node Group进行计算。

默认值off

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:设置不当可能影响查询性能。

enable_default_index_deduplication

参数说明设置btree索引默认情况下是否对键值重复的元组进行去重压缩。去重压缩功能对主键索引和唯一索引不生效。在重复键值的索引较多时,去重压缩功能可以有效降低索引占用空间。若创建索引时带有with (deduplication=on/off)语法时,优先根据deduplication参数决定该索引是否使用去重压缩功能。

参数类型:布尔型

参数单位:

取值范围

  • on:表示btree索引默认开启索引去重压缩功能。
  • off:表示btree索引默认关闭索引去重压缩功能。

默认值off

设置方式:该参数属于POSTMASTER类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值,对于非唯一索引、索引键值重复度较高,且索引占用空间较大的情况,可以打开。

设置不当的风险与影响:非唯一索引且索引键值重复度很低或者唯一的场景,去重压缩功能会使索引插入性能小幅度劣化。

enable_expr_fusion

参数说明控制SRF、表达式展平、共享聚合函数的转移状态和Step步数优化特性的开关。

参数类型:布尔型

参数单位:

取值范围

  • on:表示同时启用SRF、表达式展平、共享聚合函数的转移状态和Step步数优化特性。
  • off:表示关闭本功能。

默认值off

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值

设置不当的风险与影响:打开会增加优化器运行开销。

说明:

SRF只支持query_dop=1的场景。

stream_multiple

参数说明设置优化器计算Stream算子开销时的加权。在原代价模型的基础上,最终Stream代价将被乘以此加权参数。

说明:

此参数仅对Redistribute和Broadcast类型的Stream有效。

参数类型:浮点型

参数单位:

取值范围0 ~ DBL_MAX

默认值1

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值,并依据部署环境适时调整。

设置不当的风险与影响:设置不当会导致优化器错估Stream算子开销,从而影响查询性能。

qrw_inlist2join_optmode

参数说明控制是否使用inlist-to-join查询重写。

参数类型:字符串

参数单位:

取值范围

  • disable:关闭inlist-to-join查询重写。
  • cost_base:基于代价的inlist-to-join查询重写,即基于代价自动评估是否使用inlist-to-join查询重写。
  • rule_base:基于规则的inlist-to-join查询重写,即强制使用inlist-to-join查询重写。
  • 任意正整数(1 ~ 2147483647):inlist-to-join查询重写阈值,即list内元素个数大于该阈值,进行inlist-to-join查询重写。

默认值cost_base

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值,除非有异常场景或者发现优化器选择的计划查询性能低,需要手动调优才使用其他值。

设置不当的风险与影响:该参数会影响优化器是否进行inlist-to-join查询重写,设置不当会导致未生成更优计划。

skew_option

参数说明控制是否使用优化策略。

参数类型:枚举类型

参数单位:

取值范围off、normal、lazy

  • off:关闭策略。
  • normal:采用激进策略。对于不确定是否出现倾斜的场景,认为存在倾斜,并进行相应优化。
  • lazy:采用保守策略。对于不确定是否出现倾斜场景,认为不存在倾斜,不进行优化。

默认值normal

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:会影响优化器是否针对倾斜进行优化,设置不当会影响计划生成性能或查询执行性能。

default_limit_rows

参数说明设置生成genericplan的缺省limit估算行数。

参数类型:浮点型

参数单位:

取值范围-100 ~ DBL_MAX

  • 设置为非负数时,表示直接将设置的值作为估算limit的行数。
  • 设置为负数时,表示使用百分比的形式设置默认的估算值,负数转换为默认百分比,即-5代表5%。

默认值-10

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:设置不当可能影响带有limit算子genericplan查询的性能。

check_implicit_conversions

参数说明控制对查询中有隐式类型转换的索引列是否会生成候选索引路径进行检查。该参数可在PDB级别设置,关于该参数的使用场景请参见《开发指南》中“SQL调优指南 > 检查隐式转换的性能问题”章节。

参数类型:布尔型

参数单位:

取值范围

  • on:表示对查询中有隐式类型转换的索引列会生成候选索引路径进行检查。
  • off:表示不进行相关检查。

默认值off。在PDB场景内,若未设置该参数,则继承来自全局的设置。

说明:

将该参数设置为on时,需要同时将参数enable_fast_query_shipping设置为off,检查索引列的隐式数据类型转换的识别机制才会生效。

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:不进行检查可能导致查询语句中正则表达式无法按预期匹配。

cost_weight_index

参数说明设置index_scan的代价权重。

参数类型:浮点型

参数单位:

取值范围1e-6 ~ 1e+10

默认值1

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:会影响优化器是否选择index_scan,设置不当可能影响优化器选择非最优计划从而影响查询性能。

try_vector_engine_strategy

参数说明设置行存表走向量化执行引擎的策略。通过设置该参数,可以使包含行存表的查询转换为向量化的执行计划执行计算,从而提升类AP场景的复杂查询的执行性能。

参数类型:枚举类型

参数单位:

取值范围

  • off:表示关闭本功能,即行存表不会转换为向量的执行计划执行。
  • force:表示只要查询中不包含向量化引擎不支持的类型或者表达式,则查询的基表为行存表,强制将查询转换为向量化的执行计划执行计算。在这种情况下,针对不同的查询场景可能出现性能下降。
  • optimal:表示在force的基础上,由优化器根据查询的复杂度进行选择是否将查询语句转换为向量化的执行计划,尽可能避免转换为向量化的执行计划后出现性能下降。

默认值off

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:会影响优化器是否选择向量化的执行计划,设置不当可能会影响部分场景下查询的性能。

enable_opfusion_reuse

参数说明控制复用opfusion obj内存特性的开关。

参数类型:布尔型

参数单位:

取值范围

  • on:表示在满足条件情况下,复用opfusion obj内存。
  • off:表示关闭本功能。

默认值on

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:关闭可能会导致计划重新生成,查询性能下降。

enable_iud_fusion

参数说明控制IUD语句优化特性的开关。

参数类型:布尔型

参数单位:

取值范围

  • on:表示对输入进行类型转换时做优化处理。
  • off:表示关闭本功能。

默认值off

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值,IUD语句性能需优化时可考虑开启。

设置不当的风险与影响:打开可能会增加优化器的开销,无明显风险。

enable_cached_operator

参数说明控制算子执行态缓存特性的开关。

参数类型:布尔型

参数单位:

取值范围

  • on:表示允许缓存执行算子。
  • off:表示关闭本功能。

默认值on

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:若关闭则无法对算子执行态进行缓存,从而影响查询性能。

enable_smp_partitionwise

参数说明控制是否在SMP场景下,开启Partition-wise Join的能力。

参数类型:布尔型

参数单位:

取值范围

  • on:表示在SMP场景下,开启Partition-wise Join的能力。
  • off:表示在SMP场景下,不开启Partition-wise Join的能力。

默认值on

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:可能影响SMP场景下数据查询操作的性能。

force_smp_partitionwise_scan

参数说明在SMP场景下,打开Partition-wise Join开关enable_smp_partitionwise后,是否在全局范围内开启Partition-wise Scan的并行扫描方式。

参数类型:布尔型

参数单位:

取值范围

  • on:表示在SMP场景下,开启Partition-wise Scan的并行扫描方式。
  • off:表示在SMP场景下,不开启Partition-wise Scan的并行扫描方式。

默认值off

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:可能影响SMP场景下读取分区表数据的性能。

enable_nestagg

参数说明开启嵌套聚集功能,嵌套聚集为形如sum(min(col))的双重聚集语法。

参数类型:布尔型

参数单位:

取值范围

  • on:表示开启嵌套聚集功能。
  • off:表示关闭嵌套聚集功能。

默认值on

设置方式:该参数属于USERSET类型参数,请参考表1中对应设置方法进行设置。

设置建议:推荐使用默认值。

设置不当的风险与影响:影响嵌套聚集功能的使用。

提示

您即将访问非华为云网站,请注意账号财产安全

文档反馈

文档反馈

意见反馈

0/500

标记内容

同时提交标记内容