我有一个这样的日期:
08/Jul/2012:06:19:00 -0200
我正在尝试选择类似的内容
from_unixtime(unix_timestamp(substr(hiredate,0,10),'dd/MMM/yyyy HH:mm:ss'),'yyyy-MM-dd')
但是它不起作用。我想将其转换为2012-07-08
。我正在使用quickstart cloudera 5.12
。
答案 0 :(得分:3)
查看此两步过程是否对您有用:
unixtimestamp
unixtimestamp
(步骤1的结果)格式化为所需格式0: jdbc:hive2://beeline> select from_unixtime(unix_timestamp('08/Jul/2012:06:19:00 -0200','dd/MMM/yyyy:HH:mm:ss Z'),'yyyy-MM-dd') d;
+-------------+--+
| d |
+-------------+--+
| 2012-07-08 |
+-------------+--+
1 row selected (0.825 seconds)