hive開發中實際的日期轉換函數


 

日期函數

1. UNIX時間戳轉日期函數: from_unixtime

語法: from_unixtime(bigint unixtime[, string format])

返回值: string

說明: 轉化UNIX時間戳(從1970-01-01 00:00:00 UTC到指定時間的秒數)到當前時區的時間格式

舉例:

hive> select from_unixtime(1323308943,'yyyyMMdd') from lxw_dual;

20111208

 

2. 獲取當前UNIX時間戳函數: unix_timestamp

語法: unix_timestamp()

返回值: bigint

說明: 獲得當前時區的UNIX時間戳

舉例:

hive> select unix_timestamp() from lxw_dual;

1323309615

 

3. 日期轉UNIX時間戳函數: unix_timestamp

語法: unix_timestamp(string date)

返回值: bigint

說明: 轉換格式為"yyyy-MM-dd HH:mm:ss"的日期到UNIX時間戳。如果轉化失敗,則返回0。

舉例:

hive> select unix_timestamp('2011-12-07 13:01:03') from lxw_dual;

1323234063

 

4. 指定格式日期轉UNIX時間戳函數: unix_timestamp

 1 語法: unix_timestamp(string date, string pattern)
 2 
 3 返回值: bigint
 4 
 5 說明: 轉換pattern格式的日期到UNIX時間戳。如果轉化失敗,則返回0。
 6 
 7 舉例:
 8 
 9 hive> select unix_timestamp('20111207 13:01:03','yyyyMMdd HH:mm:ss') from lxw_dual;
10 
11 1323234063

 

5. 日期時間轉日期函數: to_date

語法: to_date(string timestamp)

返回值: string

說明: 返回日期時間字段中的日期部分。

舉例:

hive> select to_date('2011-12-08 10:03:01') from lxw_dual;

2011-12-08

 

 

6. 日期轉年函數: year

 1 語法: year(string date)
 2 
 3 返回值: int
 4 
 5 說明: 返回日期中的年。
 6 
 7 舉例:
 8 
 9 hive> select year('2011-12-08 10:03:01') from lxw_dual;
10 
11 2011
12 
13 hive> select year('2012-12-08') from lxw_dual;
14 
15 2012
16 
17  

 

7. 日期轉月函數: month

語法: month (string date)

返回值: int

說明: 返回日期中的月份。

舉例:

hive> select month('2011-12-08 10:03:01') from lxw_dual;

12

hive> select month('2011-08-08') from lxw_dual;

8

 

 

8. 日期轉天函數: day

 

 

語法: day (string date)

返回值: int

說明: 返回日期中的天。

舉例:

hive> select day('2011-12-08 10:03:01') from lxw_dual;

8

hive> select day('2011-12-24') from lxw_dual;

24

 

9. 日期轉小時函數: hour

語法: hour (string date)

返回值: int

說明: 返回日期中的小時。

舉例:

hive> select hour('2011-12-08 10:03:01') from lxw_dual;

10

 

 

10. 日期轉分鍾函數: minute

語法: minute (string date)

返回值: int

說明: 返回日期中的分鍾。

舉例:

hive> select minute('2011-12-08 10:03:01') from lxw_dual;

3

 

 

11. 日期轉秒函數: second

語法: second (string date)

返回值: int

說明: 返回日期中的秒。

舉例:

hive> select second('2011-12-08 10:03:01') from lxw_dual;

1

 

 

12. 日期轉周函數: weekofyear

語法: weekofyear (string date)

返回值: int

說明: 返回日期在當前的周數。

舉例:

hive> select weekofyear('2011-12-08 10:03:01') from lxw_dual;

49

 

 

13. 日期比較函數: datediff

語法: datediff(string enddate, string startdate)

返回值: int

說明: 返回結束日期減去開始日期的天數。

舉例:

hive> select datediff('2012-12-08','2012-05-09') from lxw_dual;

213

 

 

14. 日期增加函數: date_add

語法: date_add(string startdate, int days)

返回值: string

說明: 返回開始日期startdate增加days天后的日期。

舉例:

hive> select date_add('2012-12-08',10) from lxw_dual;

2012-12-18

 

 

15. 日期減少函數: date_sub

語法: date_sub (string startdate, int days)

返回值: string

說明: 返回開始日期startdate減少days天后的日期。

舉例:

hive> select date_sub('2012-12-08',10) from lxw_dual;

2012-11-28

 

16.DATE_FORMAT(date,format) 函數

1、date:代表具體時間字段,也可以為now()查詢當前時間;
2、format:DATE_FORMAT將傳來的Date類型數據轉為自己需要的格式,如%Y-%m-%d %H:%i:%s會將傳來的Time數據轉為"yyyy-MM-dd HH:mm:ss"格式
%Y-%m-%d %H:%i:%s 與 yyyy-MM-dd HH:mm:ss 相對應,也是最常用的格式

SELECT name as '用戶名',DATE_FORMAT(createTime,'%Y-%m-%d %H') as '時間/小時',count(*) as '訂單量' from t_order where DATE_FORMAT(createTime,'%Y-%m-%d') = '2020-11-11' GROUP BY DATE_FORMAT(createTime,'%Y-%m-%d %H');
+------------------+---------------+-----------+
| 用戶名      | 時間/小時   | 訂單量  |
+------------------+---------------+-----------+
| 剁手皇帝陳哈哈  | 2020-11-11 00 |    0 |
| 剁手皇帝陳哈哈  | 2020-11-11 01 |    10 |
| 剁手皇帝陳哈哈  | 2020-11-11 02 |    6 |
| 剁手皇帝陳哈哈  | 2020-11-11 03 |    3 |
| 剁手皇帝陳哈哈  | 2020-11-11 04 |    0 |
| 剁手皇帝陳哈哈  | 2020-11-11 05 |    0 |
| 剁手皇帝陳哈哈  | 2020-11-11 06 |    0 |
| 剁手皇帝陳哈哈  | 2020-11-11 07 |    0 |
| 剁手皇帝陳哈哈  | 2020-11-11 08 |    0 |
| 剁手皇帝陳哈哈  | 2020-11-11 09 |    0 |
| 剁手皇帝陳哈哈  | 2020-11-11 10 |    0 |
| 剁手皇帝陳哈哈  | 2020-11-11 11 |    0 |
| 剁手皇帝陳哈哈  | 2020-11-11 12 |    12 |
| 剁手皇帝陳哈哈  | 2020-11-11 13 |    6 |
| 剁手皇帝陳哈哈  | 2020-11-11 14 |    3 |
| 剁手皇帝陳哈哈  | 2020-11-11 15 |    7 |
| 剁手皇帝陳哈哈  | 2020-11-11 16 |    2 |
| 剁手皇帝陳哈哈  | 2020-11-11 17 |    3 |
| 剁手皇帝陳哈哈  | 2020-11-11 18 |    11 |
| 剁手皇帝陳哈哈  | 2020-11-11 19 |    2 |
| 剁手皇帝陳哈哈  | 2020-11-11 20 |    1 |
| 剁手皇帝陳哈哈  | 2020-11-11 21 |    3 |
| 剁手皇帝陳哈哈  | 2020-11-11 22 |    2 |
| 剁手皇帝陳哈哈  | 2020-11-11 23 |    0 |
+------------------+---------------+-----------+
24 rows in set (0.00 sec)

 

 
 


免責聲明!

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



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