ClickHouse查看执行计划(EXPLAIN语法)

1.EXPLAIN 语法示例

EXPLAIN [AST | SYNTAX | QUERY TREE | PLAN | PIPELINE | ESTIMATE | TABLE OVERRIDE] [setting = value, ...]

SELECT ... \| tableFunction(...) \[COLUMNS (...)\] \[ORDER BY ...\] \[PARTITION BY ...\] \[PRIMARY KEY\] \[SAMPLE BY ...\] \[TTL ...

]

FORMAT ...

查询计划的类型说明:

AST(抽象语法树):在AST级别优化之后的查询文本

SYNTAX(语法优化):在AST级别优化之后的查询文本,返回优化后的sql

QUERY TREE(查询树):在查询树级别优化之后的查询树

PLAN(执行计划):查询执行计划,默认是此值

PIPELINE(管道):查询执行管道

1.1AST(抽象语法树)

查询语法树执行计划

explain AST SELECT
path,code,v1
FROM
autorun_t_index
WHERE
index_id = 1227
AND cluster_id =27
AND code IN('queue_name', 'queue_allocatedmb', 'queue_availablemb','queue_allocatedvcores','queue_availablevcores')
AND update_date IN(SELECT MAX(update_date) FROM autorun_t_index WHERE index_id = 1227 AND cluster_id = 27 and update_date <='2023-08-04 01:38:48')

展示结果:

SelectQuery (children 3)
ExpressionList (children 3)
Identifier path
Identifier code
Identifier v1
TablesInSelectQuery (children 1)
TablesInSelectQueryElement (children 1)
TableExpression (children 1)
TableIdentifier autorun_t_index
Function and (children 1)
ExpressionList (children 4)
Function equals (children 1)
ExpressionList (children 2)
Identifier index_id
Literal UInt64_1227
Function equals (children 1)
ExpressionList (children 2)
Identifier cluster_id
Literal UInt64_27
Function in (children 1)
ExpressionList (children 2)
Identifier code
Literal Tuple_('queue_name', 'queue_allocatedmb', 'queue_availablemb', 'queue_allocatedvcores', 'queue_availablevcores')
Function in (children 1)
ExpressionList (children 2)
Identifier update_date
Subquery (children 1)
SelectWithUnionQuery (children 1)
ExpressionList (children 1)
SelectQuery (children 3)
ExpressionList (children 1)
Function MAX (children 1)
ExpressionList (children 1)
Identifier update_date
TablesInSelectQuery (children 1)
TablesInSelectQueryElement (children 1)
TableExpression (children 1)
TableIdentifier autorun_t_index
Function and (children 1)
ExpressionList (children 3)
Function equals (children 1)
ExpressionList (children 2)
Identifier index_id
Literal UInt64_1227
Function equals (children 1)
ExpressionList (children 2)
Identifier cluster_id
Literal UInt64_27
Function lessOrEquals (children 1)
ExpressionList (children 2)
Identifier update_date
Literal '2023-08-04 01:38:48'
Identifier TabSeparatedWithNamesAndTypes

1.2SYNTAX(语法优化)

语法优化前执行sql

explain SYNTAX SELECT
path,code,v1
FROM
autorun_t_index
WHERE
index_id = 1227
AND cluster_id =27
AND code IN('queue_name', 'queue_allocatedmb', 'queue_availablemb','queue_allocatedvcores','queue_availablevcores')
AND update_date IN(SELECT MAX(update_date) FROM autorun_t_index WHERE index_id = 1227 AND cluster_id = 27 and update_date <='2023-08-04 01:38:48')

语法优化后推荐的sql

SELECT
path,
code,
v1
FROM autorun_t_index
WHERE (index_id = 1227) AND (cluster_id = 27) AND (code IN ('queue_name', 'queue_allocatedmb', 'queue_availablemb', 'queue_allocatedvcores', 'queue_availablevcores')) AND (update_date IN ((
SELECT max(update_date)
FROM autorun_t_index
WHERE (index_id = 1227) AND (cluster_id = 27) AND (update_date <= '2023-08-04 01:38:48')
) AS _subquery132))

1.3QUERY TREE(查询树)

1.4PLAN(执行计划)

默认值就是PLAN,一般用来查看sql的执行计划,是否使用引擎,分区,索引等信息

未添加索引前

explain PLAN SELECT
path,code,v1
FROM
autorun_t_index
WHERE
index_id = 1227
AND cluster_id =27
AND code IN('queue_name', 'queue_allocatedmb', 'queue_availablemb','queue_allocatedvcores','queue_availablevcores')
AND update_date IN(SELECT MAX(update_date) FROM autorun_t_index WHERE index_id = 1227 AND cluster_id = 27 and update_date <='2023-08-04 01:38:48')

未添加索引查询计划

Expression (Projection)
CreatingSets (Create sets before main query execution)
Expression (Before ORDER BY)
Filter (WHERE)
SettingQuotaAndLimits (Set limits and quota after reading from storage)
ReadFromStorage (Log)
CreatingSet (Create set for subquery)
Expression ((Projection + Before ORDER BY))
Aggregating
Expression (Before GROUP BY)
Filter (WHERE)
SettingQuotaAndLimits (Set limits and quota after reading from storage)
ReadFromStorage (Log)

添加引擎,分区后优化结果

Expression ((Projection + Before ORDER BY))
SettingQuotaAndLimits (Set limits and quota after reading from storage)
ReadFromMergeTree

1.5PIPELINE(管道)

官网示例

EXPLAIN PIPELINE SELECT sum(number) FROM numbers_mt(100000) GROUP BY number % 4;

执行结果:

(Expression)
ExpressionTransform
(Aggregating)
Resize 4 → 1
AggregatingTransform × 4
(Expression)
ExpressionTransform × 4
(SettingQuotaAndLimits)
(ReadFromStorage)
NumbersMt × 4 0 → 1

相关推荐
派可数据BI可视化28 分钟前
商业智能BI 浅谈数据孤岛和数据分析的发展
大数据·数据库·数据仓库·信息可视化·数据挖掘·数据分析
yong999030 分钟前
C#驱动斑马打印机实现包装自动打印
java·数据库·c#
野犬寒鸦1 小时前
从零起步学习MySQL || 第五章:select语句的执行过程是怎么样的?(结合源码深度解析)
java·服务器·数据库·后端·mysql·adb
QT 小鲜肉1 小时前
【个人成长笔记】Qt 中 SkipEmptyParts 编译错误解决方案及版本兼容性指南
数据库·c++·笔记·qt·学习·学习方法
我是苏苏2 小时前
C#高级:数据库中使用SQL作分组处理4(LAG() 偏移函数)
数据库
wudl55662 小时前
股票300394(天孚通信)2025年4月20日
数据库
IvorySQL2 小时前
PostgreSQL 18 中国贡献者经验分享:开源参与的四点建议
数据库·postgresql·开源
曾凡宇先生2 小时前
openEuler安装jdk,nginx,redis
linux·开发语言·数据库·openeuler
点灯小铭3 小时前
基于单片机的四沟道步进电机玉米补种机设计与实现
数据库·单片机·嵌入式硬件·毕业设计·课程设计·期末大作业
清风6666663 小时前
基于单片机的双机串口通信与数字串存储系统设计
数据库·单片机·mongodb·毕业设计·课程设计·期末大作业