【hive 】时间差(天、小时、分、秒)和常用时间格式转

unix_timestamp()是hive系统时间,格式是timestamp,精确到秒。

unix_timestamp(ymdhms)是把时间转换成timestamp格式,是2018-05-23 07:15:50格式。

unix_timestamp() – unix_timestamp(ymdhms)是两个时间转换为timestamp之后相减,timestamp单位是秒,相减之后是两个时间之间相差的秒数。

CAST((unix_timestamp() – unix_timestamp(ymdhms)) % 60 AS int)是相差的秒数。

CAST((unix_timestamp() – unix_timestamp(ymdhms)) / 60 AS int) % 60是相差的分钟数。

CAST((unix_timestamp() – unix_timestamp(ymdhms)) / (60 * 60) AS int) % 24是相差的小时数。

concat(CAST((unix_timestamp() – unix_timestamp(ymdhms)) / (60 * 60 * 24) AS int)是相差的天数。

常用时间格式转换

固定日期转换成时间戳

select unix_timestamp(‘2016-08-16′,’yyyy-MM-dd’) –1471276800

select unix_timestamp(‘20160816′,’yyyyMMdd’) –1471276800

select unix_timestamp(‘2016-08-16T10:02:41Z’, “yyyy-MM-dd’T’HH:mm:ss’Z'”) –1471312961

16/Mar/2017:12:25:01 +0800 转成正常格式(yyyy-MM-dd hh:mm:ss)

select from_unixtime(to_unix_timestamp(’16/Mar/2017:12:25:01 +0800′, ‘dd/MMM/yyy:HH:mm:ss Z’))

时间戳转换程固定日期

select from_unixtime(1471276800,’yyyy-MM-dd’) –2016-08-16

select from_unixtime(1471276800,’yyyyMMdd’) –20160816

select from_unixtime(1471312961) —    2016-08-16 10:02:41

select from_unixtime( unix_timestamp(‘20160816′,’yyyyMMdd’),’yyyy-MM-dd’)  –2016-08-16

select date_format(‘2016-08-16′,’yyyyMMdd’) –20160816

返回日期时间字段中的日期部分

select to_date(‘2016-08-16 10:03:01’) –2016-08-16

取当前时间

select from_unixtime(unix_timestamp(),’yyyy-MM-dd HH:mm:ss’)

select from_unixtime(unix_timestamp(),’yyyy-MM-dd’)

返回日期中的年

select year(‘2016-08-16 10:03:01’) –2016

返回日期中的月

select month(‘2016-08-16 10:03:01’) –8

返回日期中的日

select day(‘2016-08-16 10:03:01’) –16

返回日期中的时

select hour(‘2016-08-16 10:03:01’) –10

返回日期中的分

select minute(‘2016-08-16 10:03:01’) –3

返回日期中的秒

select second(‘2016-08-16 10:03:01’) –1

返回日期在当前的周数

select weekofyear(‘2016-08-16 10:03:01’) –33

返回结束日期减去开始日期的天数

select datediff(‘2016-08-16′,’2016-08-11’)

返回开始日期startdate增加days天后的日期

select date_add(‘2016-08-16’,10)

返回开始日期startdate减少days天后的日期

select date_sub(‘2016-08-16’,10)

返回当天三种方式

SELECT CURRENT_DATE;

–2017-06-15

SELECT CURRENT_TIMESTAMP;–返回时分秒

–2017-06-15 19:54:44

SELECT from_unixtime(unix_timestamp());

–2017-06-15 19:55:04

返回当前时间戳

Select current_timestamp–2018-06-18 10:37:53.278

返回当月的第一天

select trunc(‘2016-08-16′,’MM’) –2016-08-01

返回当年的第一天

select trunc(‘2016-08-16′,’YEAR’) –2016-01-01

 

————————————————

版权声明:本文为CSDN博主「可乐大牛」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/qq_44173974/article/details/113829168

本文来自网络,不代表协通编程立场,如若转载,请注明出处:https://net2asp.com/98cf1d94e6.html