暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

AWS redshift->hdb pg(Greenplum), CONVERT_TIMEZONE 时区转换函数兼容

digoal 2018-10-18
386

作者

digoal

日期

2018-10-18

标签

PostgreSQL , redshift , hdb pg , 时区转换


背景

redshift 时区转换函数

https://docs.amazonaws.cn/redshift/latest/dg/CONVERT_TIMEZONE.html

CONVERT_TIMEZONE 函数

CONVERT_TIMEZONE 将时间戳从一个时区转换为另一个时区。

语法

CONVERT_TIMEZONE ( ['source_timezone',] 'target_timezone', 'timestamp')

参数

source_timezone

(可选)当前时间戳的时区。默认值为 UTC。有关更多信息,请参阅 时区使用说明。

target_timezone

新时间戳的时区。有关更多信息,请参阅 时区使用说明。

timestamp

时间戳列,或隐式转换为时间戳的表达式。

hdb pg 自定义UDF兼容CONVERT_TIMEZONE

https://www.postgresql.org/docs/devel/static/functions-datetime.html

自定义函数如下

```
create or replace function CONVERT_TIMEZONE (text,text,timestamp) returns timestamp as $$
select timezone($2, timezone ($1,$3));
$$ language sql strict ;

create or replace function CONVERT_TIMEZONE (text,timestamp) returns timestamp as $$
select timezone($1, timezone ('UTC',$2));
$$ language sql strict ;
```

数据库时区代码

select * from pg_timezone_abbrevs ; abbrev | utc_offset | is_dst --------+------------+-------- ACDT | 10:30:00 | t ACSST | 10:30:00 | t ACST | 09:30:00 | f ACT | -05:00:00 | f CDT | -05:00:00 | t CEST | 02:00:00 | t CET | 01:00:00 | f CETDST | 02:00:00 | t CHADT | 13:45:00 | t CHAST | 12:45:00 | f CHUT | 10:00:00 | f CKT | -10:00:00 | f CLST | -03:00:00 | t CLT | -03:00:00 | t COT | -05:00:00 | f UT | 00:00:00 | f UTC | 00:00:00 | f ....

验证如下

```
postgres=# select CONVERT_TIMEZONE('CLT','UTC','2018-01-01');
convert_timezone


2018-01-01 03:00:00
(1 row)

postgres=# select CONVERT_TIMEZONE('CLT','CET','2018-01-01');
convert_timezone


2018-01-01 04:00:00
(1 row)

postgres=# select CONVERT_TIMEZONE('CET','2018-01-01');
convert_timezone


2018-01-01 01:00:00
(1 row)

postgres=# select CONVERT_TIMEZONE('CLT','2018-01-01');
convert_timezone


2017-12-31 21:00:00
(1 row)
```

参考

https://www.postgresql.org/docs/devel/static/functions-datetime.html

https://docs.amazonaws.cn/redshift/latest/dg/CONVERT_TIMEZONE.html

PostgreSQL 许愿链接

您的愿望将传达给PG kernel hacker、数据库厂商等, 帮助提高数据库产品质量和功能, 说不定下一个PG版本就有您提出的功能点. 针对非常好的提议,奖励限量版PG文化衫、纪念品、贴纸、PG热门书籍等,奖品丰富,快来许愿。开不开森.

9.9元购买3个月阿里云RDS PostgreSQL实例

PostgreSQL 解决方案集合

德哥 / digoal's github - 公益是一辈子的事.

digoal's wechat

文章转载自digoal,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论