Hive列转行的SQL语法详解

1104
2024/12/20 21:31:37
栏目: 云计算
开发者测试专用服务器限时活动,0元免费领,库存有限,领完即止! 点击查看>>

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;

这个查询的工作原理如下:

  1. SELECT id, item:选择iditems列。
  2. FROM example_table:从example_table表中获取数据。
  3. 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表中的数组列转换为多行。

辰迅云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

推荐阅读: Hive数据库的优点和缺点是什么