接下来的步骤包括:
1)将 AST 转换为 QueryBlock 进一步转换为 OperatorTree;
2)对 OperatorTree 进行逻辑优化(LogicalOptimizer);
3)将 OperatorTree 转换为 TaskTree(任务树);
4)对 TaskTree 进行物理优化(PhysicalOptimizer)。
之所以将这 4 个步骤写在一起,是因为这几个步骤在源码中存在于一个方法中。
1 compile 方法(接 2.4.2 节 compile 方法继续往下)


2 analyze 方法
本文详细解读了Hive源码中HQL如何转化为MapReduce任务的过程,包括AST到QueryBlock的转换,逻辑优化,OperatorTree转化为TaskTree,以及物理优化等步骤。通过分析`analyzeInternal`和`execute`方法,深入理解Hive查询的执行机制。
订阅专栏 解锁全文
577

被折叠的 条评论
为什么被折叠?



