如何将实际上是带时区的日期的字符串转换为 Presto 中的时间戳? [英] How do I convert a string which is actually a date with timezone to a timestamp in Presto?
本文介绍了如何将实际上是带时区的日期的字符串转换为 Presto 中的时间戳?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
示例:2017-12-24 23:59:59.000 PST
Example : 2017-12-24 23:59:59.000 PST
这不起作用
select date_parse('2017-12-24 23:59:59.000 PST','%Y-%m-%d %T.%f %x')
当然我可以截断 TZ 来解决
Sure I can truncate the TZ which will solve
select date_parse(substr('2017-12-24 23:59:59.000 PST',1,23),'%Y-%m-%d %T.%f')
有没有办法在不截断 TZ 的情况下做到这一点?
Is there a way to do this without truncating the TZ ?
推荐答案
date_parse
似乎不支持时区,使用 parse_datetime
代替:
date_parse
doesn't seem to support time zones, use parse_datetime
instead:
presto> select parse_datetime('2017-12-24 23:59:59.000 PST', 'YYYY-MM-dd HH:mm:ss.SSS z');
_col0
---------------------------------------------
2017-12-24 23:59:59.000 America/Los_Angeles
(1 row)
这篇关于如何将实际上是带时区的日期的字符串转换为 Presto 中的时间戳?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文