Hive 时间操作
Hive 时间转换
UNIX时间戳概念:因为UNIX时间戳只是一个秒数,一个UNIX时间戳在不同时区看来,时间是不同的。
如UNIX时间戳0,在0时区看来是1970-01-01 00:00:00,在东八区看来是1970-01-01 08:00:00。
hive常用时间操作示例
-- 返回UNIX时间戳代表的(格林威治零时区)时间,默认格式如下。
select from_unixtime(1);
1970-01-01 00:00:01
select from_unixtime(1 ,'yyyyMMdd hh:mm:ss');
19700101 12:00:01
-- 获取当前时间的UNIX时间戳(时区无关的),返回值bigint(对应spark中Long)。
select unix_timestamp();
1579508709
-- 获取日期部分
select to_date('2020-01-20 11:40:03');
2020-01-20
-- 同样还有返回年、月、日、时、分、秒、周的函数
select year('2020-01-20 11:40:03');
2020
select year('2020-01-20');
2020
-- 获取月份数
select month('2020-01-20 11:40:03');
1
select month('2020-01-20');
1
-- 获取月份中的天数
select day('2020-01-20 10:03:01');
20
select day('2020-01-20');
20
select hour('2020-01-20 11:40:01');
11
select hour('11:40:01');
11
-- 获取时间中的分钟数
select minute('2020-01-20 11:40:01');
40
-- 获取时间中的秒数
select second('2020-01-20 11:40:01');
1
-- 获取当天在一年中的周数
select weekofyear('2020-01-20 11:40:01');
31
--返回两个日期相隔天数
select datediff('2020-01-20','2019-12-09');
42
--增加天数
select date_add('2020-01-20',10);
2020-01-30
--减少天数
select date_sub('2020-01-20',10);
2020-01-10
-- 1、hive取得当前日期时间:
-- 1.1) 取得当前日期:
select current_date();
2020-01-20
-- 1.2) 取得当前日期时间:
select current_timestamp();
2020-01-20 08:37:45.076
-- 1.3) hive取得当前时间戳:
select unix_timestamp();
1579509477
-- 1.4) 时间戳转日期:
select from_unixtime(1579509477,'yyyy-MM-dd HH:dd:ss');
2020-01-20 08:20:57
-- 1.5) hive取得当前时间(0时区):
select from_unixtime(unix_timestamp(),'yyyy-MM-dd HH:dd:ss');
2020-01-20 08:20:00
-- 2、hive自动计算其他日期(昨天,今天):
-- hive中日期加减函数:date_add(start_date,num_days)
-- 2.1) 取得昨天日期:
select date_add(from_unixtime(unix_timestamp(),'yyyy-MM-dd'),-1);
select date_sub(from_unixtime(unix_timestamp(),'yyyy-MM-dd'),1);
select date_format(date_add(from_unixtime(unix_timestamp(),'yyyy-MM-dd'),-1),'yyyy-MM-dd');
2020-01-19
-- 2.2) 取得明天日期:
select date_add(from_unixtime(unix_timestamp(),'yyyy-MM-dd'),1);
select date_sub(from_unixtime(unix_timestamp(),'yyyy-MM-dd'),-1);
2020-01-21
-- 2.3)hive取得两个日期之间差值(差值为天数):
-- datediff(date1,date2):date1大于date2,返回值为正,否则,返回值为负。
select datediff(from_unixtime(unix_timestamp(),'yyyy-MM-dd'),date_add(from_unixtime(unix_timestamp(),'yyyy-MM-dd'),-10));
10
select datediff(from_unixtime(unix_timestamp(),'yyyy-MM-dd'),date_add(from_unixtime(unix_timestamp(),'yyyy-MM-dd'),10));
-10
-- 2.4) 字符串转时间(字符串必须为:yyyy-MM-dd格式)
select to_date('2020-01-20 12:12:12');
2020-01-20
-- 2.5) 日期、时间戳、字符串类型格式化输出标准时间格式:
select date_format(current_timestamp(),'yyyy-MM-dd HH:mm:ss');
2020-01-20 09:00:13
select date_format(current_date(),'yyyyMMdd');
20200120
select date_format('2020-01-20','yyyy-MM-dd HH:mm:ss'); --字符串必须满足yyyy-MM-dd格式
2020-01-20 00:00:00
-- 2.6) utc时间转换:
select from_utc_timestamp(current_timestamp(),8);
2020-01-20 09:00:51.749
select to_utc_timestamp(current_timestamp(),8);
2020-01-20 09:01:06.89
备注:
作者:Jason Zeng
博客:http://www.cnblogs.com/zengming/
GItHub:https://github.com/lovelifeming
严正声明:
1.由于本博客部分资源来自互联网,版权均归原作者所有。转载的目的是用于学术交流与讨论学习,将不对任何资源负法律责任。
2.若无意中侵犯到您的版权利益,请来信联系我,我会在收到信息后会尽快给予处理!
3.所有资源内容仅供学习交流之用,请勿用作商业用途,谢谢。
4.如有转发请注明出处,来源于http://www.cnblogs.com/zengming/,谢谢合作。
Hive 时间操作的更多相关文章
- Hive时间操作[转]
时间字段格式化 from_unixtime(unix_timestamp(VisitTime),'yyyy-MM-dd') 日期函数UNIX时间戳转日期函数: from_unixtime语法: f ...
- HIVE 时间操作函数
转自http://www.oratea.net/?p=944 日期函数UNIX时间戳转日期函数: from_unixtime语法: from_unixtime(bigint unixtime[, ...
- Hive 时间操作函数(转)
1.日期函数UNIX时间戳转日期函数: from_unixtime 语法: from_unixtime(bigint unixtime[, string format]) 返回值: string ...
- spark使用Hive表操作
spark Hive表操作 之前很长一段时间是通过hiveServer操作Hive表的,一旦hiveServer宕掉就无法进行操作. 比如说一个修改表分区的操作 一.使用HiveServer的方式 v ...
- Java Calendar 类的时间操作
Java Calendar 类的时间操作 标签: javaCalendar时间Date 2013-07-30 17:53 140401人阅读 评论(7) 收藏 举报 分类: 所有(165) Java ...
- paip.日期时间操作以及时间戳uapi php java python 总结
paip.日期时间操作以及时间戳uapi php java python 总结 ///uapi Date 函数 | Day 函数 | Hour 函数 | Minute 函数 | Month 函数 | ...
- [时间操作] C#DateFormat时间帮助类 (转载)
点击下载 DateFormat.rar 主要功能如下 返回每月的第一天和最后一天 看下面代码吧 /// <summary> /// 类说明:时间操作类 /// 编 码 人:苏飞 /// 联 ...
- Flex时间操作
小弟是Flex新手,最近一段时间领导要求使用Flex开发B/S的一些项目,需要用到时间上的一些操作.上网查询一番好多人都说不好操作,有的甚至非常麻烦.基于此,小弟整理了一些关于Flex时间操作的经验, ...
- JAVA中的时间操作
java中的时间操作不外乎这四种情况: 1.获取当前时间 2.获取某个时间的某种格式 3.设置时间 4.时间的运算 好,下面就针对这四种情况,一个一个搞定. 一.获取当前时间 有两种方式可以获得,第一 ...
随机推荐
- EL表达式详细教程
EL 全名为Expression Language EL 语法很简单,它最大的特点就是使用上很方便.接下来介绍EL主要的语法结构: ${sessionScope.user.sex} 所有EL都是以${ ...
- Win10下JDK环境搭建的两种方法
jdk1.8--64位官网下载的百度网盘 https://pan.baidu.com/s/1A7jYfupwMWZawb5z_RSdJg 提取码: 92eu 第一种方法(建议) 变量名: ...
- 第十届javaB(5)
试题 E: 迷宫 本题总分:15 分[问题描述] 下图给出了一个迷宫的平面图,其中标记为 1 的为障碍,标记为 0 的为可 以通行的地方.010000 000100 001001 110000迷宫的入 ...
- django Highcharts制作图表--显示CPU使用率
Highcharts 是一个用纯JavaScript编写的一个图表库. Highcharts 能够很简单便捷的在web网站或是web应用程序添加有交互性的图表 Highcharts 免费提供给个人学习 ...
- BUG漏测的原因总结,以及如何处理
一.漏测的概率 漏测,是指软件产品的缺陷没有在测试过程中被发现,而是在版本发布之后,用户在使用过程中发现存在的缺陷. 二.预防漏测的意义 我们都知道,缺陷越早被发现,发现和解决缺陷所花的成本就越小,如 ...
- SpringMVC之转发重定向
package com.tz.controller; import org.springframework.stereotype.Controller; import org.springframew ...
- Soldier and Badges
题目链接:https://vjudge.net/problem/CodeForces-546B AC代码: #include<iostream> #include<algorithm ...
- 会员VS广告:陷入两难抉择的视频网站该如何自救
互联网实在是非常奇妙,其在让一个行业兴起时,却又对传统行业造成严重冲击.比如电商不断创造销售神话,由此成为线下实体店严重萎靡,客流量和销售额直线下降的重要原因之一.但与此同时,因互联网而狂奔的新兴 ...
- 一个很实用的css技巧简析
我是小雨小雨,专注于更新有趣.实用内容的小伙,如果内容对大家有一点帮助,那么就请动动手指,给个关注.点赞支持一下吧. ^ - ^ 序言 前两天接到一个需求,其中包括一个有序的列表,我们今天就来看看这个 ...
- 奉上简单的.Net后端开发模板
假定一个场景,开始做开发的你,领导走到你的面前说道:"小伙子,看了简历和最近的工作表现,很不错,现在交给一个任务,开发一个简单的CMS后端接口吧,前端有人配合你",当时你内心读白: ...