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

相关推荐
ID_1800790547325 分钟前
(淘宝 / 京东)商品评论 API 接口:技术实战案例与架构分析
服务器·数据库·架构
爱莉希雅&&&26 分钟前
Zabbix监控初步搭建
linux·运维·数据库·mysql·zabbix
狼与自由28 分钟前
mysql到clickhouse
数据库·mysql·clickhouse
六月雨滴28 分钟前
Oracle 数据库之归档日志
数据库·oracle·dba
土狗TuGou31 分钟前
SQL内功笔记 · 第6篇:窗口函数的使用ROW_NUMBER等
java·数据库·后端·sql·mysql
川石课堂软件测试36 分钟前
使用mock进行接口测试教程
数据库·python·功能测试·测试工具·华为·单元测试·appium
Solis程序员1 小时前
MongoDB 超全入门到实战:从原理、CRUD到高可用架构
数据库·mongodb·架构
yurenpai(27届找实习中)1 小时前
redis_点评(26.附近店铺——实现附近商家功能)
数据库·spring boot·redis
BullSmall1 小时前
异构数据库(通俗 + 核心知识点)
数据库
Rick19931 小时前
索引下推(ICP):在已经用到联合索引的前提下,减少回表次数,提升查询效率
数据库