Hive列转行的SQL语法详解
Hive SQL中,可以使用EXPLODE
函数将数组类型的列转换为多行
CREATE TABLE example_table (id INT,items ARRAY<STRING>);
现在,假设我们要将items
列中的每个元素转换为一个单独的行。可以使用以下查询:
SELECT id, itemFROM example_tableLATERAL 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
。执行此查询后,您将看到以下结果:
iditem1 a1 b1 c2 x2 y2 z
这样,您就可以将Hive表中的数组列转换为多行。
下一篇:hive分隔符对数据存储有何要求
Hive
webacc.exe是什么文件?webacc.exe是不是病毒
WINSYS.vbs是什么文件?WINSYS.vbs是不是病毒
winssh.exe是什么文件?winssh.exe是不是病毒
wt.exe是什么文件?wt.exe是不是病毒
winsysetm.exe是什么文件?winsysetm.exe是不是病毒
winstrve.exe是什么文件?winstrve.exe是不是病毒
winsysupd7.exe是什么文件?winsysupd7.exe是不是病毒
winsysupd.exe是什么文件?winsysupd.exe是不是病毒
winsysupd2.exe是什么文件?winsysupd2.exe是不是病毒
winsysupd8.exe是什么文件?winsysupd8.exe是不是病毒