SQL执行计划是一个节点树,显示 GaussDB 执行一条SQL语句时执行的详细步骤。每一个步骤为一个数据库运算符。
使用EXPLAIN命令可以查看优化器为每个查询生成的具体执行计划。EXPLAIN给每个执行节点都输出一行,显示基本的节点类型和优化器为执行这个节点预计的开销值。如 图1 所示。
GaussDB 对执行计划提供了normal、pretty、summary、run四种显示格式:
gaussdb=# explain select * from t1,t2 where t1.c1=t2.c2; id | operation | E-rows | E-width | E-costs ----+-----------------------------------------+--------+---------+--------- 1 | -> Streaming (type: GATHER) | 20 | 180 | 29.07 2 | -> Hash Join (3,5) | 20 | 180 | 27.75 3 | -> Streaming(type: REDISTRIBUTE) | 20 | 104 | 14.31 4 | -> Seq Scan on t2 | 20 | 104 | 13.13 5 | -> Hash | 21 | 76 | 13.13 6 | -> Seq Scan on t1 | 20 | 76 | 13.13 (6 rows)
通过设置GUC参数explain_perf_mode,可以显示不同格式的执行计划。下文的用例默认显示pretty格式。
除了设置不同的执行计划显示格式外,还可以通过不同的EXPLAIN用法,显示不同详细程度的执行计划信息。常见有如下几种,关于更多用法请参见 EXPLAIN 语法说明。
EXPLAIN 为了测量运行时在执行计划中每个节点的开销,EXPLAIN ANALYZE或EXPLAIN PERFORMANCE会在当前查询执行上增加性能分析的开销。在一个查询上运行EXPLAIN ANALYZE或EXPLAIN PERFORMANCE有时会比普通查询明显的花费更多的时间。超支的数量依赖于查询的本质和使用的平台。详情参见当前版本的《云数据库 GaussDB 开发指南(1.x版本)》的“SQL参考 > SQL语法 > EXPLAIN”章节。
因此,当定位SQL运行慢问题时,如果SQL长时间运行未结束,建议通过EXPLAIN命令查看执行计划,进行初步定位。如果SQL可以运行出来,则推荐使用EXPLAIN ANALYZE或EXPLAIN PERFORMANCE查看执行计划及其实际的运行信息,以便更准确地定位问题原因。
EXPLAIN PERFORMANCE轻量化执行方式与EXPLAIN PERFORMANCE保持一致,在原来的基础上减少了性能分析的时间,执行时间与SQL执行时间的差异显著减少。