如何在 AWS Athena 中转换时区

Posted

技术标签:

【中文标题】如何在 AWS Athena 中转换时区【英文标题】:How do I convert time zones in AWS Athena 【发布时间】:2021-12-07 10:37:16 【问题描述】:

在 Athena 中,我在数据库中存储了时区和日期时间,我想使用存储的时区来转换日期时间

我可以让这个查询工作

SELECT (my_date_time) AT TIME ZONE 'America/Los_Angeles' AS converted_time
FROM table_one;

如何用表中字段的值替换硬编码时区,例如

SELECT (my_date_time) AT TIME ZONE my_timezone AS converted_time
FROM table_one;

我在尝试第二个查询时收到此错误

第 8:41 行:输入“my_timezone”不匹配。期望:'ZONE'

编辑: 添加到 Guru Strons 的回答中,这就是我使用 at_timezone 的方式

WITH dataset (t, tz) AS (
   SELECT
     table_one.my_date_time,
     table_two.timezone
   FROM table_one
   LEFT JOIN table_two ON table_one.id = table_two.table_one_id
 )
SELECT t, tz, at_timezone(t, tz) FROM dataset

【问题讨论】:

【参考方案1】:

Ahtena 支持at_timezone 功能:

WITH dataset (t, tz) AS (
    VALUES (TIMESTAMP '2001-08-22 03:04:05.321 America/Los_Angeles', 'America/New_York')
)

select at_timezone(t, tz)
FROM dataset

输出:

_col0
2001-08-22 06:04:05.321 America/New_York

【讨论】:

以上是关于如何在 AWS Athena 中转换时区的主要内容,如果未能解决你的问题,请参考以下文章

如何将我的 Bigquery 查询转换为 AWS Athena 查询?

aws glue / pyspark - 如何使用 Glue 以编程方式创建 Athena 表

如何使用 AWS Glue 将许多 CSV 文件转换为 Parquet

在 Zeppelin 中保存 AWS Athena 查询的结果

在 Athena 上转换为带时区的时间戳失败

如何将行转入 AWS Athena 中的列?