sql技巧-产生连续日期(时间)序列

本文基于hive1.1.0-cdh5.12.1

要求:通过sql生成一段连续的日期,入2021-01-01至2021-01-31

参考结果:

dt

2021-01-01
2021-01-02
2021-01-03
2021-01-04

参考实现:

--由于hive不能递归,所有使用posexplode生成连续序号

with t as  
(
select  date_add( to_date('2021-01-01'),i) as dt -- 基础日期
from (select  30 as days ) t --需要加多少天
LATERAL VIEW 
posexplode(split(repeat(',',days),',')) pe as i, x 
)
select * from t;
+-------------+--+
|    t.dt     |
+-------------+--+
| 2021-01-01  |
| 2021-01-02  |
| 2021-01-03  |
| 2021-01-04  |
| 2021-01-05  |
| 2021-01-06  |
| 2021-01-07  |
| 2021-01-08  |
| 2021-01-09  |
| 2021-01-10  |
| 2021-01-11  |
| 2021-01-12  |
| 2021-01-13  |
| 2021-01-14  |
| 2021-01-15  |
| 2021-01-16  |
| 2021-01-17  |
| 2021-01-18  |
| 2021-01-19  |
| 2021-01-20  |
| 2021-01-21  |
| 2021-01-22  |
| 2021-01-23  |
| 2021-01-24  |
| 2021-01-25  |
| 2021-01-26  |
| 2021-01-27  |
| 2021-01-28  |
| 2021-01-29  |
| 2021-01-30  |
| 2021-01-31  |
+-------------+--+

 

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

周小科

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值