【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
