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

相关推荐
常利兵4 分钟前
Android 开发探秘:View.post()为何能获取View宽高
java·数据库·sql
xdpcxq102926 分钟前
Redis 故障排查 + 跨语言重构场景实测
数据库·redis·重构
LSL666_39 分钟前
IService——查询(下)
java·开发语言·数据库·mybatisplus·iservice
磊 子40 分钟前
mysql数据库2
数据库
2301_818419011 小时前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python
jinanwuhuaguo1 小时前
OpenClaw v2026.3.23 深度技术分析报告:平台地基的加固与成熟度宣言
运维·数据库·人工智能·openclaw
2301_793804691 小时前
Python异步编程入门:Asyncio库的使用
jvm·数据库·python
2301_810160951 小时前
NumPy入门:高性能科学计算的基础
jvm·数据库·python
add45a1 小时前
超越Python:下一步该学什么编程语言?
jvm·数据库·python
孤影过客2 小时前
Flutter优雅构建:从零打造开发级工作流
arm开发·数据库·flutter