Hive查询计划

1、EXTENDED 语句会在执行计划中产生关于算子(Operator)的额外信息,这些信息都是典型的物理信息,如文件名称等

sql 复制代码
EXPLAIN [EXTENDED|CBO|AST|DEPENDENCY|AUTHORIZATION|LOCKS|VECTORIZATION|ANALYZE] query

最外层开始,包含两个大的部分:

****stage dependencies:****各个stage之间的依赖性

****stage plan:****各个stage的执行计划

(1)TableScan:表扫描操作,map端第一个操作肯定是加载表,所以就是表扫描操作,常见的属性:

alias:表名称;

Statistics:表统计信息,包含表中数据条数,数据大小等;

(2)Select Operator:选取操作,常见的属性 :

expressions:需要的字段名称及字段类型;

outputColumnNames:输出的列名称;

Statistics:表统计信息,包含表中数据条数,数据大小等;

(3)Group By Operator:分组聚合操作,常见的属性:

aggregations:显示聚合函数信息;

mode:聚合模式,值有;

hash:随机聚合,就是hash partition;

partial:局部聚合;

final:最终聚合;

keys:分组的字段,如果没有分组,则没有此字段;

outputColumnNames:聚合之后输出列名;

Statistics:表统计信息,包含分组聚合之后的数据条数,数据大小等。

(4)Reduce Output Operator:输出到reduce操作,常见属性:

sort order:值为空 不排序;值为 + 正序排序,值为 - 倒序排序;

值为 ± 排序的列为两列,第一列为正序,第二列为倒序.

(5)Filter Operator:过滤操作,常见的属性:

predicate:过滤条件,如sql语句中的where id>=1,则此处显示(id >= 1);

(6)Map Join Operator:join 操作,常见的属性:

condition map:join方式 ,如Inner Join 0 to 1 Left Outer Join0 to 2 keys: join 的条件字段;

outputColumnNames:join 完成之后输出的字段;

Statistics:join 完成之后生成的数据条数,大小等。

(7)File Output Operator:文件输出操作,常见的属性:

compressed:是否压缩;

table:表的信息,包含输入输出文件格式化方式,序列化方式等。

(8)Fetch Operator 客户端获取数据操作,常见的属性:

limit,值为 -1 表示不限制条数,其他值为限制的条数。

2、 explain dependency的用法

explain dependency用于描述一段SQL需要的数据来源,输出是一个json格式的数据,里面包含以下两个部分的内容:

input_partitions:描述一段SQL依赖的数据来源表分区,里面存储的是分区名的列表,如果整段SQL包含的所有表都是非分区表,则显示为空。

input_tables:描述一段SQL依赖的数据来源表,里面存储的是Hive表名的列表。

3、 explain authorization 的用法

通过explain authorization可以知道当前SQL访问的数据来源(INPUTS)和数据输出(OUTPUTS),以及当前Hive的访问用户 (CURRENT_USER)和操作(OPERATION)。

相关推荐
moxiaoran57531 小时前
uni-app学习笔记二十九--数据缓存
笔记·学习·uni-app
自小吃多4 小时前
STC8H系列 驱动步进电机
笔记·单片机
moxiaoran57536 小时前
uni-app学习笔记三十--request网络请求传参
笔记·学习·uni-app
weixin_307779137 小时前
Linux下GCC和C++实现统计Clickhouse数据仓库指定表中各字段的空值、空字符串或零值比例
linux·运维·c++·数据仓库·clickhouse
明月醉窗台9 小时前
qt使用笔记二:main.cpp详解
数据库·笔记·qt
Shaoxi Zhang10 小时前
NVM常用命令记录
笔记
wind_one110 小时前
STM32[笔记]--1.前置准备
笔记·stm32·单片机
jackson凌11 小时前
【Java学习笔记】String类(重点)
java·笔记·学习
a_1571532498612 小时前
SpringCloud学习笔记-4
笔记·学习·spring cloud
RestCloud13 小时前
如何通过ETLCloud实现跨系统数据同步?
数据库·数据仓库·mysql·etl·数据处理·数据同步·集成平台