【超详细】HIVE 日期函数(当前日期、时间戳转换、前一天日期等)

2024-02-22 06:28

本文主要是介绍【超详细】HIVE 日期函数(当前日期、时间戳转换、前一天日期等),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 相关文献
    • 常量:当前日期、时间戳
    • 前一天日期、后一天日期
    • 获取日期中的年、季度、月、周、日、小时、分、秒等
    • 时间戳转换
      • 秒 to 时间戳
      • 时间戳 to 秒
      • 日期 to 时间戳
    • 日期之间月、天数差

作者:小猪快跑

基础数学&计算数学,从事优化领域5年+,主要研究方向:MIP求解器、整数规划、随机规划、智能优化算法。

如有错误,欢迎指正。如有更好的算法,也欢迎交流!!!——@小猪快跑

相关文献

  • LanguageManual UDF - Apache Hive - Apache Software Foundation

常量:当前日期、时间戳

返回类型名称样例描述
datecurrent_datecurrent_date = 2024-01-01返回查询评估开始时的当前日期(从 Hive 1.2.0 开始)。同一查询中的所有current_date调用都返回相同的值。
timestampcurrent_timestampcurrent_timestamp = 2024-01-01 00:00:00返回查询评估开始时的当前时间戳(从 Hive 1.2.0 开始)。同一查询中的所有current_date调用都返回相同的值。

前一天日期、后一天日期

返回类型名称样例
pre 2.1.0: string 2.1.0 on: datedate_add(date/timestamp/string startdate, tinyint/smallint/int days)date_add(‘2008-12-31’, 1) = 2009-01-01
pre 2.1.0: string 2.1.0 on: datedate_sub(date/timestamp/string startdate, tinyint/smallint/int days)date_sub(‘2008-12-31’, 1) = 2008-12-30
date_sub(current_date, 1) -- 昨天
date_add(current_date, 1) -- 明天

获取日期中的年、季度、月、周、日、小时、分、秒等

返回类型名称样例描述
intyear(string date)year("1970-01-01") = 1970
year("1970-01-01 00:00:00") = 1970
intquarter(date/timestamp/string)quarter('2015-04-08') = 2季度
intmonth(string date)month("1970-11-01 00:00:00") = 11
month("1970-11-01") = 11
intweekofyear(string date)weekofyear("1970-11-01 00:00:00") = 44
weekofyear("1970-11-01") = 44
intday(string date) dayofmonth(date)day("1970-11-01 00:00:00") = 1
day("1970-11-01") = 1
inthour(string date)hour('2009-07-30 12:58:59') = 12小时
hour('12:58:59') = 12
intminute(string date)
intsecond(string date)
stringlast_day(string date)last_day('2015-01-14') = 2015-01-31当月最后一天
stringnext_day(string start_date, string day_of_week)next_day('2015-01-14', 'TU') = 2015-01-20给定日期后最近的星期几

时间戳转换

秒 to 时间戳

返回类型名称样例描述
stringfrom_unixtime(bigint unixtime[, string pattern])from_unixtime(0)=1970-01-01 00:00:00(1970-01-01 00:00:00 UTC)之后多少秒的时间,注意不同时区结果不同

时间戳 to 秒

返回类型名称样例描述
bigintunix_timestamp(string date)unix_timestamp(‘2009-03-20 11:30:01’) = 1237573801(1970-01-01 00:00:00 UTC)之后多少秒,注意不同时区结果不同

日期 to 时间戳

返回类型名称样例描述
bigintunix_timestamp(string date, string pattern)unix_timestamp(‘2009-03-20’, ‘yyyy-MM-dd’) = 1237532400(1970-01-01 00:00:00 UTC)之后多少秒,注意不同时区结果不同 https://docs.oracle.com/javase/8/docs/api/java/text/SimpleDateFormat.html

日期之间月、天数差

返回类型名称样例描述
doublemonths_between(date1, date2)months_between(‘1997-02-28 10:30:00’, ‘1996-10-30’) = 3.94959677返回日期 date1 和 date2 之间的月数(从 Hive 1.2.0 开始)。如果 date1 晚于 date2,则结果为正数。如果 date1 早于 date2,则结果为负数。 date1 和 date2 类型:timestamp | ‘yyyy-MM-dd’ | ‘yyyy-MM-dd HH:mm:ss’
intdatediff(string enddate, string startdate)datediff(‘2009-03-01’, ‘2009-02-27’) = 2

这篇关于【超详细】HIVE 日期函数(当前日期、时间戳转换、前一天日期等)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/734386

相关文章

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

C++操作符重载实例(独立函数)

C++操作符重载实例,我们把坐标值CVector的加法进行重载,计算c3=c1+c2时,也就是计算x3=x1+x2,y3=y1+y2,今天我们以独立函数的方式重载操作符+(加号),以下是C++代码: c1802.cpp源代码: D:\YcjWork\CppTour>vim c1802.cpp #include <iostream>using namespace std;/*** 以独立函数

实例:如何统计当前主机的连接状态和连接数

统计当前主机的连接状态和连接数 在 Linux 中,可使用 ss 命令来查看主机的网络连接状态。以下是统计当前主机连接状态和连接主机数量的具体操作。 1. 统计当前主机的连接状态 使用 ss 命令结合 grep、cut、sort 和 uniq 命令来统计当前主机的 TCP 连接状态。 ss -nta | grep -v '^State' | cut -d " " -f 1 | sort |

函数式编程思想

我们经常会用到各种各样的编程思想,例如面向过程、面向对象。不过笔者在该博客简单介绍一下函数式编程思想. 如果对函数式编程思想进行概括,就是f(x) = na(x) , y=uf(x)…至于其他的编程思想,可能是y=a(x)+b(x)+c(x)…,也有可能是y=f(x)=f(x)/a + f(x)/b+f(x)/c… 面向过程的指令式编程 面向过程,简单理解就是y=a(x)+b(x)+c(x)

沁恒CH32在MounRiver Studio上环境配置以及使用详细教程

目录 1.  RISC-V简介 2.  CPU架构现状 3.  MounRiver Studio软件下载 4.  MounRiver Studio软件安装 5.  MounRiver Studio软件介绍 6.  创建工程 7.  编译代码 1.  RISC-V简介         RISC就是精简指令集计算机(Reduced Instruction SetCom

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

arduino ide安装详细步骤

​ 大家好,我是程序员小羊! 前言: Arduino IDE 是一个专为编程 Arduino 微控制器设计的集成开发环境,使用起来非常方便。下面将介绍如何在不同平台上安装 Arduino IDE 的详细步骤,包括 Windows、Mac 和 Linux 系统。 一、在 Windows 上安装 Arduino IDE 1. 下载 Arduino IDE 打开 Arduino 官网

批处理以当前时间为文件名创建文件

批处理以当前时间为文件名创建文件 批处理创建空文件 有时候,需要创建以当前时间命名的文件,手动输入当然可以,但是有更省心的方法吗? 假设我是 windows 操作系统,打开命令行。 输入以下命令试试: echo %date:~0,4%_%date:~5,2%_%date:~8,2%_%time:~0,2%_%time:~3,2%_%time:~6,2% 输出类似: 2019_06

GPT系列之:GPT-1,GPT-2,GPT-3详细解读

一、GPT1 论文:Improving Language Understanding by Generative Pre-Training 链接:https://cdn.openai.com/research-covers/languageunsupervised/language_understanding_paper.pdf 启发点:生成loss和微调loss同时作用,让下游任务来适应预训