我的Hive表中有以下时间戳的字符串表示形式:

20130502081559999

我需要将其转换为这样的字符串:
2013-05-02 08:15:59

我尝试了以下({code} >>> {result}):
from_unixtime(unix_timestamp('20130502081559999', 'yyyyMMddHHmmss')) >>> 2013-05-03 00:54:59
from_unixtime(unix_timestamp('20130502081559999', 'yyyyMMddHHmmssMS')) >>> 2013-09-02 08:15:59
from_unixtime(unix_timestamp('20130502081559999', 'yyyyMMddHHmmssMS')) >>> 2013-05-02 08:10:39

转换为时间戳然后使用unixtime似乎很奇怪,执行此操作的正确方法是什么?

编辑
我想到了。
from_unixtime(unix_timestamp(substr('20130502081559999',1,14), 'yyyyMMddHHmmss')) >>> 2013-05-02 08:15:59

要么
from_unixtime(unix_timestamp('20130502081559999', 'yyyyMMddHHmmssSSS')) >>> 2013-05-02 08:15:59

还有...还有更好的方法吗?

最佳答案

不确定“更好的方式”是什么意思,但您始终可以write your own function处理日期转换。

08-28 04:40