1. 程式人生 > 實用技巧 >hive 時間相關的函式

hive 時間相關的函式

yyyy-MM-dd與yyyyMMdd000000轉換的三種方法
 
方法一:date_format(只支援yyyy-MM-dd -> yyyyMMdd000000)

select date_format('2019-10-07', 'yyyyMMdd000000')
-- 20191007000000
 

方法二:from_unixtime + unix_timestamp

select from_unixtime(unix_timestamp('2019-10-07', 'yyyy-MM-dd'), 'yyyyMMdd000000')
-- 20191007000000

select from_unixtime(unix_timestamp(substr('20191007000000',1,8),'yyyyMMdd'),'yyyy-MM-dd')
-- 2019-10-07


固定日期轉換成時間戳
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

文章轉自:https://www.cnblogs.com/littlewu/p/9364273.html