hive按周维度计算汇总

碰到按日,月,周,年计算的需求

weekofyear()函数,它返回给定日期的周数(1到53之间的数字)
weekofyear()函数要求一年的第一周必须大于3天

image.png

遇到跨年需要先判断当前周所属年份,
'2022-01-01' 是21年第52周

image.png

对于跨年日期,我们可以先得到它下周一的日期,然后减去4天,年份就是多的那一部分所在的年份,然后再拼上周数

select concat(year(date_sub(next_day('2022-01-01','monday'),4)), '-', weekofyear('2022-01-01'));
image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容