hive 计算周几_HIVE 计算指定日期本周的第一天和最后一天

select

day

,(day,1) -- 时间

,date_add(day,1 - dayofweek(day)) as week_first_day -- 本周第一天_周日

,date_add(day,7 - dayofweek(day)) as week_last_day -- 本周最后一天_周六

,date_add(day,1 - case when dayofweek(day) = 1 then 7 else dayofweek(day) - 1 end) as week_first_day -- 本周第一天_周一

,date_add(day,7 - case when dayofweek(day) = 1 then 7 else dayofweek(day) - 1 end) as week_last_day -- 本周最后一天_周日

-- dayofweek在hive2.2.0开始支持,低版本的hive原生未提供dayofweek函数(获取一个日期是星期几的方法),

-- 所以只有我们自己编写udf函数提供,udf就不说了,在这里给出了一个使用hive原生函数获取星期几的技巧。

,date_format(from_unixtime(unix_timestamp('20190808','yyyyMMdd'),'yyyy-MM-dd'),'u') as dayofweek1 --本周第几天 u必须小写

,date_format('2019-08-08','u') --本周第几天 u必须小写

,7- datediff(next_day('2019-08-07',"Sunday"),'2019-08-07') --另外一种方式实现本周几

,dayofmonth(day,1) --本月本月第几


版权声明:本文为weixin_39776239原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。