openGauss学习笔记-225 openGauss性能调优-系统调优-配置向量化执行引擎
openGauss数据库支持行执行引擎和向量化执行引擎,分别对应行存表和列存表。
- 一次一个batch,读取更多数据,节省IO。
- batch中记录较多,CPU cache命中率提升。
- Pipeline模式执行,函数调用次数少。
- 一次处理一批数据,效率高。
openGauss数据库所以对于分析类的复杂查询能够获得更好的查询性能。但列存表在数据插入和数据更新上表现不佳,对于存在数据频繁插入和更新的业务无法使用列存表。
为了提升行存表在分析类的复杂查询上的查询性能,openGauss数据库提供行存表使用向量化执行引擎的能力。通过设置GUC参数try_vector_engine_strategy,可以将包含行存表的查询语句转换为向量化执行计划执行。
行存表转换为向量化执行引擎执行不是对所有的查询场景都适用。参考向量化引擎的优势,如果查询语句中包含表达式计算、多表join、聚集等操作时,通过转换为向量化执行能够获得性能提升。从原理上分析,行存表转换为向量化执行,会产生转换的开销,导致性能下降。而上述操作的表达式计算、join操作、聚集操作转换为向量化执行之后,能够获得获得性能提升。所以