hive 時間函數


1、日期函數

1)時間戳:unix_timestamp/from_unixtime

select unix_timestamp();  --查詢當前時間的時間戳,返回 1486524284
select unix_timestamp('2017-02-08 11:15:50');  --查詢指定時間的時間戳,返回 1486523750 (若轉換失敗返回0)
select unix_timestamp('20170208 11:00:00','yyyyMMdd HH:mm:ss');  --轉換指定格式時間的時間戳
select from_unixtime(1486523750);  --查詢指定時間戳的時間,默認格式yyyy-MM-dd HH:mm:ss ,返回 2017-02-08 11:15:50
select from_unixtime(1486523750,'yyyyMMdd');  --查詢指定時間戳的時間,轉換成指定格式,返回 20170208

2)日期提取年月日時分秒+周:year/month/day/hour/minute/second/weekofyear

select year('2017-02-08 11:15:50'),month('2017-02-08 11:15:50'),day('2017-02-08 11:15:50'),hour('2017-02-08 11:15:50'),minute('2017-02-08 11:15:50'),second('2017-02-08 11:15:50'),weekofyear('2017-02-08 11:15:50');  --查詢指定日期的年月日時分秒和周,返回 2017、2、8、11、15、50、6

3)日期時間轉日期:to_date

select to_date('2017-02-08 11:15:50'); --查詢指定日期時間中的日期。返回 2017-02-08

4)日期比較

--日期比較,結束時間距離開始時間的天數。datediff(string enddate, string startdate)
select datediff('2017-02-02','2017-01-31');--返回 2
--日期增加和減少。date_sub (string startdate, int days)
select date_add('2017-01-31',2); --返回 2017-02-02
select date_sub('2017-02-02',2);  --返回 2017-01-31

5)日期偏移

--自定義日期操作函數(返回帶橫線的日期):get_date
select get_date();--返回當前日期,返回  2017-02-09
select get_date(-2);--返回當前日期往前偏移2天的日期 ,返回  2017-02-07
--自定義日期操作函數(返回不帶橫線的日期):get_dt_date
select get_dt_date();--獲取當前日期,返回 20170209
select get_dt_date(get_date(-2));--獲取當前日期偏移,轉為不帶橫桿的格式
select get_dt_date('2017-02-02',-2);--20170131
---------------------
作者:helen_elva
來源:CSDN
原文:https://blog.csdn.net/zhlelva/article/details/54924507?utm_source=copy
版權聲明:本文為博主原創文章,轉載請附上博文鏈接!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM