高级SQL优化系列之分组排序优化

应用开发2025-11-05 06:20:4393

问题定义

在如何创建高效的高级数据库索引中,我们说到过,优优化可以通过有序的化系索引(B+tree)来避免排序操作,从而提升查询的分组性能。但是排序如果排序子句或分组子句中的字段来自不同的表,那么数据库优化器就无法利用索引的高级有序性来避免一次排序操作。

但是优优化如果能从查询中推断出排序字段与另一个表的某个字段具有等值的关系,可以使用此字段来替换原排序字段,化系从而利用索引的分组有序性,在进行排序或分组时避免一次排序操作,排序从而提升SQL查询性能。高级

譬如对于以下的优优化SQL查询:

复制select customer.* from customer, orders where c_custkey=o_custkey order by c_name, o_custkey;1.

排序字段为 C_NAME, o_custkey,来自不同的两个表,但是化系在查询中条件c_custkey=o_custkey,所以可以用c_custkey来替换o_custkey, 重写后的SQL如下:

复制select customer.* from customer, orders where c_custkey=o_custkey order by c_name, c_custkey;1.

适用条件

分组排序优化是针对查询块(Queryblock)来进行的,多个查询块可以独立进行此优化。分组分组排序优化的源码下载排序适用条件如下:

在一个查询块中存在等于或大于2的排序字段或分组字段。排序字段或分组字段是数据表中的列(无函数或计算)。排序字段或分组字段来自不同的数据表。在此查询块中可以推导出与排序或分组字段的等值关系。经过推导替换后的排序或分组字段来自同一个数据表。

性能验证

重写优化前的执行计划如下,可以看到执行时间为10ms,代价7849.64,执行计划的最后一步是排序操作。

重写优化后,排序子句中的o_custkey被替换为c_custkey,执行计划如下。可以看到,优化后排序操作被消除了,其他部分没有变化。执行时间减少到2.58ms,性能提升了287.6%。

PawSQL对此优化的支持

PawSQL针对所有数据库默认开启此优化,

自动优化:用户输入待优化SQL后,PawSQL对其进行自动化优化,亿华云案例SQL的优化详情如下。

规则启用:用户可以在自己的默认优化设置或是定义每个优化任务的时候自主启用或禁用该选项。

关于PawSQL

PawSQL专注数据库性能优化的自动化和智能化,支持MySQL,PostgreSQL,Opengauss,Oracle等数据库,提供的SQL优化产品包括

PawSQL Cloud,在线自动化SQL优化工具,支持SQL审查,智能查询重写、基于代价的索引推荐,适用于数据库管理员及数据应用开发人员。PawSQL Advisor,IntelliJ 插件, 适用于数据应用开发人员,可以IDEA/DataGrip应用市场通过名称搜索“PawSQL Advisor”安装。PawSQL Engine, 是PawSQL系列产品的后端优化引擎,可以以docker镜像的方式独立安装部署,并通过http/json的接口提供SQL优化服务。免费信息发布网
本文地址:http://www.bzuk.cn/html/97b9899804.html
版权声明

本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。

全站热门

电脑恢复重置教程(一步步教你如何进行电脑恢复重置,让电脑焕然一新)

自建Git服务器系列——Gitea(Gogs的孪生兄弟)

51CTO OpenHarmony技术社区:做开发者社区要长期有耐心

AnnotationProcessor 处理器问题怎么深度定位?

海信65EC780UC电视的功能和性能综合评测(畅享震撼影音体验,高清画质与智能操控一体化)

浅析Servlet过滤器

把文件上传到Linux服务器有多少种方法

通过虚拟硬件原型 加速边缘智能系统创新

友情链接

滇ICP备2023006006号-33