hive序列生成,如何生成HIVE中的日期系列? (创建表)

Suppose I currently have a table that has 1 row for each account and the data in the tables are:

Account Number

Start Date

End Date

Now I'd like to create a new table that has 1 row for each day the account is open, i.e. 1 day for each row between the start and end dates (inclusive) for each account.

E.g.

Table 1

Account Number Start Date End Date

123 1-Jan-17 1-Jul-17

456 1-Feb-17 4-May-17

Table 2 (Desired table)

Account Number Day

123 1-Jan-17

123 1-Jan-17

...

123 1-Jul-17

456 1-Feb-17

456 2-Feb-17

...

456 4-May-17

I know in Postgresql there's a function called 'generate series' that would allow you to do that easily. I'm wondering if there's a similar function in HIVE that would allow you to do that as well?

Thanks!

解决方案select t.AccountNumber

,date_add (t.StartDate,pe.i) as Day

from Table1 t

lateral view

posexplode(split(space(datediff(t.EndDate,t.StartDate)),' ')) pe as i,x

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值