阅读量:3
Hive SQL中,可以使用EXPLODE函数将数组类型的列转换为多行
CREATE TABLE example_table (
id INT,
items ARRAY<STRING>
);
现在,假设我们要将items列中的每个元素转换为一个单独的行。可以使用以下查询:
SELECT id, item
FROM example_table
LATERAL VIEW INLINE(items) items_table AS item;
这个查询的工作原理如下:
SELECT id, item:选择id和items列。FROM example_table:从example_table表中获取数据。LATERAL VIEW INLINE(items) items_table AS item:使用LATERAL VIEW子句将items列中的数组转换为多行。INLINE函数用于将数组展开为多行。items_table是展开后的临时表,其中每个元素都单独的行。AS item将展开后的表中的一个列命名为item。
执行此查询后,您将看到以下结果:
id item
1 a
1 b
1 c
2 x
2 y
2 z
这样,您就可以将Hive表中的数组列转换为多行。
以上就是关于“Hive列转行的SQL语法详解”的相关介绍,筋斗云是国内较早的云主机应用的服务商,拥有10余年行业经验,提供丰富的云服务器、租用服务器等相关产品服务。云服务器资源弹性伸缩,主机vCPU、内存性能强悍、超高I/O速度、故障秒级恢复;电子化备案,提交快速,专业团队7×24小时服务支持!
简单好用、高性价比云服务器租用链接:https://www.jindouyun.cn/product/cvm