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:选择iditems列。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表中的数组列转换为多行。


上一篇:kafka cmak如何进行负载均衡

下一篇:hive分隔符对数据存储有何要求


Hive
Copyright © 2002-2019 测速网 www.inhv.cn 皖ICP备2023010105号
测速城市 测速地区 测速街道 网速测试城市 网速测试地区 网速测试街道
温馨提示:部分文章图片数据来源与网络,仅供参考!版权归原作者所有,如有侵权请联系删除!

热门搜索 城市网站建设 地区网站制作 街道网页设计 大写数字 热点城市 热点地区 热点街道 热点时间 房贷计算器