Hive中日期处理
1、日期函数UNIX时间戳转日期函数:from_unixtime()
函数 | 格式 | 返回值 | 说明 |
---|---|---|---|
from_unixtime | from_unixtime(bigint unixtime[, string format]) | string | 转化UNIX时间戳(从1970-01-01 00:00:00 UTC到指定时间的秒数)到当前时区的时间格式 |
hive (temp)> select from_unixtime(1323308943,'yyyyMMdd') from dual;
20111208
hive (temp)> select from_unixtime(1323308943,'yyyy-MM-dd') from dual;
2011-12-08
2、当前UNIX时间戳函数: unix_timestamp()
2.1 获取当前UNIX时间戳函数
函数 | 格式 | 返回值 | 说明 |
---|---|---|---|
unix_timestamp | unix_timestamp() | bigint | 获得当前时区的UNIX时间戳 |
hive (temp)> select unix_timestamp() from dual;
1472105939
2.2 日期转UNIX时间戳函数
函数 | 格式 | 返回值 | 说明 |
---|---|---|---|
unix_timestamp | unix_timestamp(string date) | bigint | 转换格式为"yyyy-MM-dd HH:mm:ss"的日期到UNIX时间戳。转化失败,则返回0 |
hive (temp)> select unix_timestamp('2016-08-25 13:02:03') from dual;
1472101323
2.3 指定格式日期转UNIX时间戳函数
函数 | 格式 | 返回值 | 说明 |
---|---|---|---|
unix_timestamp | unix_timestamp(string date, string pattern) | bigint | 转换格式为"yyyyMMdd HH:mm:ss"的日期到UNIX时间戳。转化失败,则返回0 |
hive (temp)> select unix_timestamp('20160825 13:02:03','yyyyMMdd HH:mm:ss') from dual;
1472101323
3、日期时间转日期函数: to_date()
函数 | 格式 | 返回值 | 说明 |
---|---|---|---|
to_date | to_date(string timestamp) | string | 返回日期时间字段中的日期部分 |
hive (temp)> select to_date('2016-12-08 10:03:01') from dual;
2016-12-08
4、日期转年函数: year()
函数 | 格式 | 返回值 | 说明 |
---|---|---|---|
year | year(string date) | int | 返回日期中的年 |
hive (temp)> select year('2016-12-08 10:03:01') from dual;
2016
hive (temp)> select year('2016-12-08') from dual;
2016
5、日期转月函数: month()
函数 | 格式 | 返回值 | 说明 |
---|---|---|---|
month | month(string date) | int | 返回日期中的月份 |
hive (temp)> select month('2016-12-08 10:03:01') from dual;
12
hive (temp)> select month('2016-11-08') from dual;
11
6、日期转天函数: day()
函数 | 格式 | 返回值 | 说明 |
---|---|---|---|
day | day(string date) | int | 返回日期中的天 |
hive (temp)> select day('2016-12-08 10:03:01') from dual;
8
hive (temp)> select day('2016-11-18') from dual;
18
7、日期转小时函数: hour()
函数 | 格式 | 返回值 | 说明 |
---|---|---|---|
hour | hour(string date) | int | 返回日期中的小时 |
hive (temp)> select hour('2016-12-08 10:03:01') from dual;
10
8、日期转分钟函数: minute()
函数 | 格式 | 返回值 | 说明 |
---|---|---|---|
minute | minute(string date) | int | 返回日期中的分钟 |
hive (temp)> select minute('2016-12-08 10:03:01') from dual;
3
9、日期转秒函数: second()
函数 | 格式 | 返回值 | 说明 |
---|---|---|---|
second | second(string date) | int | 返回日期中的秒 |
hive (temp)> select second('2016-12-08 10:03:01') from dual;
1
10、日期转周函数: weekofyear()
函数 | 格式 | 返回值 | 说明 |
---|---|---|---|
weekofyear | weekofyear(string date) | int | 返回日期在当前的周数 |
hive (temp)> select weekofyear('2016-12-08 10:03:01') from dual;
49
11、日期比较函数: datediff(string enddate, string startdate)
函数 | 格式 | 返回值 | 说明 |
---|---|---|---|
datediff | datediff(string enddate, string startdate) | int | 返回结束日期减去开始日期的天数 |
hive (temp)> select datediff('2016-12-08','2016-12-02') from dual;
6
12、日期增加函数: date_add(string startdate, int days)
函数 | 格式 | 返回值 | 说明 |
---|---|---|---|
date_add | date_add(string startdate, int days) | string | 返回开始日期startdate增加days天后的日期 |
hive (temp)> select date_add('2016-12-08',10) from dual;
2016-12-18
#当前日期为2016-08-25,在此基础上加7天
hive (temp)> select date_add(from_unixtime(unix_timestamp(),'yyyy-MM-dd'),7) from dual;
2016-09-01
13、日期减少函数:date_sub (string startdate, int days)
函数 | 格式 | 返回值 | 说明 |
---|---|---|---|
date_sub | date_sub(string startdate, int days) | string | 返回开始日期startdate减少days天后的日期 |
hive (temp)> select date_sub('2016-12-08',10) from dual;
2016-11-28
#当前日期为2016-08-25,在此基础上减7天
hive (temp)> select date_sub(from_unixtime(unix_timestamp(),'yyyy-MM-dd'),7) from dual;
2016-08-18
作者:一刀Q
链接:http://www.jianshu.com/p/e30395941f9c
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
Hive中日期处理的更多相关文章
- Hive中日期函数总结
--Hive中日期函数总结: --1.时间戳函数 --日期转时间戳:从1970-01-01 00:00:00 UTC到指定时间的秒数 select unix_timestamp(); --获得当前时区 ...
- hive时间日期函数及典型场景应用
1.hive取得当前日期时间: 1.1) 取得当前日期: select current_date(); 1.2) 取得当前日期时间: select current_timestamp(); 1.3) ...
- hive中时间操作(二)
转:https://blog.csdn.net/qq646748739/article/details/77997276 --Hive中日期函数总结:--1.时间戳函数--日期转时间戳:从1970-0 ...
- Hive中自定义函数
Hive的自定义的函数的步骤: 1°.自定义UDF extends org.apache.hadoop.hive.ql.exec.UDF 2°.需要实现evaluate函数,evaluate函数支持重 ...
- 关于sparksql操作hive,读取本地csv文件并以parquet的形式装入hive中
说明:spark版本:2.2.0 hive版本:1.2.1 需求: 有本地csv格式的一个文件,格式为${当天日期}visit.txt,例如20180707visit.txt,现在需要将其通过spar ...
- 漫谈数据仓库之拉链表(原理、设计以及在Hive中的实现)
本文将会谈一谈在数据仓库中拉链表相关的内容,包括它的原理.设计.以及在我们大数据场景下的实现方式. 全文由下面几个部分组成: 先分享一下拉链表的用途.什么是拉链表. 通过一些小的使用场景来对拉链表做近 ...
- sqoop 从oracle导数据到hive中,date型数据时分秒截断问题
oracle数据库中Date类型倒入到hive中出现时分秒截断问题解决方案 1.问题描述: 用sqoop将oracle数据表倒入到hive中,oracle中Date型数据会出现时分秒截断问题,只保留了 ...
- hive中时间操作(一)
转:https://blog.csdn.net/u012474716/article/details/78925319/ hive中常用的时间为时间戳和日期格式之间的转换 常用的函数为: to_dat ...
- 【hive 日期函数】Hive常用日期函数整理
1.to_date:日期时间转日期函数 select to_date('2015-04-02 13:34:12');输出:2015-04-02122.from_unixtime:转化unix时间戳到当 ...
随机推荐
- HMM代码实践
本文主要转载于:http://www.52nlp.cn/hmm-learn-best-practices-eight-summary 这个文章是边看边实践加上自己的一些想法生成的初稿..... 状态转 ...
- 一些常用的CDN列表
Microsoft Ajax Content Delivery Network 点击查看详细列表
- codevs 1085 数字游戏 dp或者暴搜
1085 数字游戏 2003年NOIP全国联赛普及组 时间限制: 1 s 空间限制: 128000 KB 题目描述 Description 丁丁最近沉迷于一个数字游戏之中.这个游戏看似简单 ...
- flask学习(三):flask入门(URL)
一. flask简介 flask是一款非常流行的python web框架,出生于2010年,作者是Armin Ronacher,本来这个项目只是作者在愚人节的一个玩笑,后来由于非常受欢迎,进而成为一个 ...
- 创建一个最简单的SpringBoot应用
已经来实习了一段时间了,从开始接触到SpringBoot框架到现在一直都感觉SpringBoot框架实在是为我们带来了巨大遍历之处,之前一直在用并没有总结一下,现在有空从零开始写点东西,也算是对基础的 ...
- 论Sava(),SaveOrUpdate(),Merge()区别
一.Save(): 用于将一个临时对象转变为持久化对象,也就是将一个新的业务实体保存到数据库中:相当于jdbc的insert. <假如两个实体之间有关系(例如employee表和address表 ...
- 个人知识管理系统Version1.0开发记录(02)
第 一 步 做 什 么 我们该如何入手呢?先来看看目前常用的三个方法. 1.从事物产生的源头出发,层层推进,步步验证,最后开花结果.这种方法经常用于科研项目,或者三期以后的工程,国家政府项目用的较多. ...
- Linux下第一次Node尝试
由于需求所定,必须在服务器上使用nodejs,第一次使用过程记录下来. 首先是安装node,这里可以下载到各个版本的node:https://nodejs.org/download/ 我是进入rele ...
- LVS模式二:隧道模式(Tun)
一.IP隧道(IP Tunneling) ip隧道是一个将ip报文封装到另一个ip报文的技术,这可以使得目标为一个ip地址的数据报文被封装和转发到另一个ip地址.ip隧道技术也成为ip封装技术. ...
- MVC4中视图获取控制器中返回的json格式数据
再开发MVC项目时,有时只需要从控制器中返回一个处理的结果,这时返回Json格式的数据非常的方便,在Controller中,提供了几种返回类型和方法,如: Content() 返回文本类型的Conte ...