hive中返回星期几

60 篇文章 2 订阅
在Hive原生版本中,目前并没有返回星期几的函数。
除了利用java自己编写udf外,也可以利用现有hive函数实现。

方法格式:pmod(datediff('#date#', '任意年任意一个星期日的日期'), 7) 。

如:
2012-01-01刚好是星期日。
pmod(datediff('#date#', '2012-01-01'), 7)  
返回值:int
说明:1、返回值为“0-6”(“0-6”分别表示“星期日-星期六”);2、需要注意pmod和 datediff 函数的使用方法。

变通一下,一样可以达到相同的目的:
pmod(datediff(#date#, '1920-01-01') - 3, 7)
select pmod(datediff(#date#, '2018-01-01') - 1, 7)
select pmod(datediff('2018-06-04', '2018-01-01') - 6, 7);
select pmod(datediff('2018-06-09', '2018-01-01') - 6, 7);
select pmod(datediff('2018-06-04', '2018-01-01') + 1, 7);
涉及函数解析:
1、datediff 是两个日期相减的函数,hive日期函数可以见附录:
日期相减函数:datediff
语法:datediff(string enddate, string startdate)
返回值: int
说明: 返回两个时间参数的相差天数。
2、 pmod 是正取余函数:
正取余函数 : pmod
语法: pmod(int a, int b),pmod(double a, double b)
返回值: int double

说明: 返回正的a除以b的余数


另外,日期转周函数: weekofyear(返回当前日期是本年的第几周函数

语法:   weekofyear (string date) 
返回值: int
说明: 返回日期在当前的周数。

hive> select weekofyear('2016-02-16');
OK
7
Time taken: 0.198 seconds, Fetched: 1 row(s)
hive> select weekofyear('2018-06-05');
OK
23
Time taken: 0.452 seconds, Fetched: 1 row(s)
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值