HiveSQL之lateral view

lateral view是hiveQL中的一个高级功能,用于和表生成函数一起,来处理嵌套数组和结构的数据,特别是在处理复杂的数据结构如JSON或数组内嵌套数组时特别有用。它允许用户在每一行上应用TGF(表生成函数),将生成的元素作为多行返回,或者多列返回。

原理

常规情况下,SQL查询是对行进行操作的,每行数据都是独立的,如果想对一行中某列数据进行拆分成多行或者多列,SQL中的单独查询是不允许的。lateral view解决了这个问题,它允许将TGF结果,"侧视"到原始数行旁边,实际上是将TGF的输出与原始行的其他列结合起来形成新的行集。

表生成函数(table-generating functions)TGF

explode

将数组或者映射转换为多行,对于数组,每个元素成为一行;对于映射每个键值对成为一行。

复制代码
SELECT id, number
FROM example_table
LATERAL VIEW explode(numbers) tbl AS number;

json_tuple

解析JSON格式的字符串,每个key成为一行

相关推荐
.又是新的一天.10 小时前
02_Servlet
hive·hadoop·servlet
wuli玉shell10 小时前
Bitmap原理及Hive去重方式对比
数据仓库·hive·hadoop
尘客.1 天前
DataX从Mysql导数据到Hive分区表案例
数据库·hive·mysql
钊兵2 天前
hivesql是什么数据库?
大数据·hive
IvanCodes3 天前
九、HQL DQL七大查询子句
大数据·数据库·hive
火龙谷4 天前
【hadoop】sqoop案例 hive->mysql
hive·hadoop·sqoop
IvanCodes5 天前
六、Hive 分桶
大数据·hive
IvanCodes5 天前
七、深入 Hive DDL:管理表、分区与洞察元数据
数据仓库·hive·hadoop
若兰幽竹5 天前
【HBase整合Hive】HBase-1.4.8整合Hive-2.3.3过程
数据库·hive·hbase
多多*6 天前
Java反射 八股版
java·开发语言·hive·python·sql·log4j·mybatis