hive中行转列,生成新的列方法

hive中行转列,生成新的列方法

具体sql,根据日期自动转换

select
  t.index as index,
  concat_ws('', collect_set(t.1_month)) as month_1,
  concat_ws('', collect_set(t.2_month)) as month_2,
  concat_ws('', collect_set(t.3_month)) as month_3
from
  (
    select
      index,
      case when month = substr(add_months(trunc(current_date(),'MM'), -3),0,7) then ytd else '' end as 3_month,
      case when month = substr(add_months(trunc(current_date(),'MM'), -2),0,7) then ytd else '' end as 2_month,
      case when month = substr(add_months(trunc(current_date(),'MM'), -1),0,7) then ytd else '' end as 1_month
    from
      base
  ) t
group by t.index

效果

原始数据
原始数据

转换后数据
转换后

参考链接

https://blog.csdn.net/weixin_37536446/article/details/81166972?utm_medium=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-1.channel_param&depth_1-utm_source=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-1.channel_param

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值