如何将实际上是带时区的日期的字符串转换为 Presto 中的时间戳? [英] How do I convert a string which is actually a date with timezone to a timestamp in Presto?

查看:32
本文介绍了如何将实际上是带时区的日期的字符串转换为 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屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆