日期函數
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)