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

相关推荐
YA33313 分钟前
java基础(十)sql的mvcc
数据库
weixin_307779134 小时前
VS Code配置MinGW64编译SQLite3库
开发语言·数据库·c++·vscode·算法
SelectDB4 小时前
Apache Doris 4.0 AI 能力揭秘(一):AI 函数之 LLM 函数介绍
数据库·人工智能·数据分析
我是哈哈hh5 小时前
【MySQL】在UBuntu环境安装以及免密码登录入门
linux·数据库·mysql·ubuntu
HeyZoeHey5 小时前
Mybatis执行sql流程(一)
java·sql·mybatis
喪彪5 小时前
MySQL新手教学
数据库·mysql·adb
丘大梨8 小时前
QT 基础聊天应用项目文档
运维·数据库·系统架构
HMBBLOVEPDX8 小时前
MySQL的多版本并发控制(MVCC):
数据库·mysql·mvcc
.用户昵称已存在.8 小时前
MongoDB 从入门到精通:安装配置与基础操作指令详解
数据库·mongodb