将'Mon Dec 12 10:55:11 UTC 2016'转换为Hive中的日期时间

问题描述 投票:1回答:1

我无法在Hive中将以下字符串转换为datetime。

Mon Dec 12 10:55:11 UTC 2016

我用过date_format('Mon Dec 12 10:55:11 UTC 2016','dd-MM-yyyy')。但是我得到的结果是NULL。任何帮助将不胜感激。

hadoop hive
1个回答
1
投票

使用unix_timestamp(string date, string pattern)given date format中的字符串转换为从Unix Epoch(1970-01-01 00:00:00 UTC)传递的秒数。然后使用from_unixtime()转换为required format

您的初始格式为'EEE MMM dd HH:mm:ss z yyyy'

转换为yyyy-MM-dd HH:mm:ss(默认):

select from_unixtime(unix_timestamp('Mon Dec 12 10:55:11 UTC 2016','EEE MMM dd HH:mm:ss z yyyy'));

返回:

2016-12-12 10:55:11 

转换为yyyy-MM-dd

select from_unixtime(unix_timestamp('Mon Dec 12 10:55:11 UTC 2016','EEE MMM dd HH:mm:ss z yyyy'),'yyyy-MM-dd');

返回:

2016-12-12
© www.soinside.com 2019 - 2024. All rights reserved.