hive 计算周几_【hive】求日期是星期几

在Hive原生版本中,目前并没有返回星期几的函数。

除了利用java自己编写udf外,也可以利用现有hive函数实现。

方法格式:

pmod(datediff('#date#', '任意年任意一个星期日的日期'), 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的余数

如:2012-01-01刚好是星期日。

pmod(datediff('#date#', '2012-01-01'), 7)

返回值:int,“0-6”(“0-6”分别表示“星期日-星期六”)

注意:这里的日期必须是'string'类型的格式为'yyyy-MM-dd',因为datediff()函数对参数的要求

补充:当后边的日期不是周日的时候,我们可以对datediff结果进行加减到周日即可

例如:2018-01-01是周一,我们可以在datediff基础上+1/-6.

为什么是周一要+1呢,因为对于一整周的时间是少了一天.

变通一下,一样可以达到相同的目的:

select pmod(datediff('2018-06-04', '2018-01-01') - 6, 7);

select pmod(datediff('2018-06-04', '2018-01-01') + 1, 7);

附赠:bigint类型的日期转换成string(yyyy-MM-DD)类型的日期

from_unixtime(unix_timestamp(cast(20180707 as string),'yyyymmdd'),'yyyy-mm-dd')

20180707 -> '2018-07-07'

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值