Hive SQL:实现炸列(列转行)以及逆操作(行转列)

目录

列转行

函数:

EXPLODE(ARRAY):将ARRAY中的每一元素转换为每一行

EXPLODE(MAP):将MAP中的每个键值对转换为两行,其中一行数据包含键,另一行数据包含值

数据样例:

1、将每天的课程,拆成日期和课程单独一条的

sql 复制代码
-- split(a.concat_lesson, ',') :将concat_lesson转换为array类型
select a.week_type, 
       a.concat_lesson,
       b.data_dup
from
(
select '周一' as week_type, '历史,生物,西方文化' as concat_lesson
union all select '周二','线性代数,数据结构,C语言'
union all select '周三','轮滑'

) as a
lateral view explode(split(a.concat_lesson, ',')) b as data_dup -- 炸列依据

结果:

2、将每天的 课程数 和 瞌睡数拆开,分别和日期形成一行

sql 复制代码
select a.week_type, 
       a.concat_lesson,
       b.data_dup,
       split(b.data_dup,':')[0] as col_name, -- 提取冒号分割的第一部分
       split(b.data_dup,':')[1] as col_value -- 提取冒号分割的第二部分
from
(
select '周一' as week_type, '课程数:3节,瞌睡数:4次' as concat_lesson
union all select '周二','课程数:2节,瞌睡数:1次'
union all select '周三','课程数:1节,瞌睡数:0次'

) as a
lateral view explode(split(a.concat_lesson, ',')) b as data_dup -- 炸列依据

结果:

这里在进行完列转行后(黄色框),还利用split进一步提取了 信息名称和对应值(绿色框)

在实际应用中,要炸列的信息(对上述的concat_lesson)可能不是来自一个字段,可能来自多表的不同字段。这时候可能需要自己构造。类似:

sql 复制代码
-- concat_lesson中信息不是来自同一个表时,可以借助concat构造
-- 然后再利用上述方式取值,主要应用于构造一维表
select t1.week_type
    ,concat('记录01:课程数:',t1.lesson_count,',',
            '记录02:瞌睡数:',t2.nap_count,',',
            '记录03:天气:',t3.weather) as concat_lesson
from t1 
left join t2 on ...
left join t3 on ...

行转列

CONCAT_WS(STRING SEP, ARRAY ):以指定分隔符SEP将ARRAY中的元素拼接成字符串

sql 复制代码
select t.name_p,
        concat_ws(',',collect_list(cast(t.hobby as string))) 
from 
(
 select 'A' AS name_p ,'swim,draw,sing' as hobby
  union all select 'A','run'
  union all select 'B','run'
) as t
group by t.name_p

结果:

相关推荐
顾得泉8 分钟前
零基础学习MySQL---MySQL入门
数据库·mysql·centos
xintaiideas8 分钟前
深⼊理解MySQL Innodb存储引擎的缓冲池、事务、索引底层工作原理,掌握 MySQL 主从同步,读写分离技术以及集群的搭建,具备分库分表,SQL调优经验
数据库·sql·mysql
琪小新38 分钟前
MySQL 9.0 发布了!
数据库·mysql
泷泷_1 小时前
SQL注入实战
数据库·sql·sqlserver·sql注入
山登绝顶我为峰 3(^v^)31 小时前
Linux 程序打包
linux·运维·数据库
天才的白鸟1 小时前
hive命令和参数
数据仓库·hive·hadoop
ronshi1 小时前
MySQL生成日期维度表
数据库·mysql
喜欢猪猪2 小时前
注解的原理?如何自定义注解?
java·数据库·python
对许3 小时前
SQL经典面试题
sql
大数据小朋友3 小时前
小时候的子弹击中了现在的我-hive进阶:案例解析(第18天)
大数据·数据仓库·hive·hadoop·分布式·sql