• 【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'

  • 相关阅读:
    第一次个人编程作业
    第一次博客作业
    动态规划 01背包学习中
    学习dijk最短路径中
    蓝桥杯 小盆友排队
    蓝桥杯 地宫取宝
    简单的BFS学习笔记
    C趣味100道之58.拉丁方的一些想法。
    蓝桥杯 错误票据--!偶然间发现,然后呵呵!
    函数实现计算标准差
  • 原文地址:https://www.cnblogs.com/zzhangyuhang/p/9858157.html
Copyright © 2020-2023  润新知