加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

PostgreSQL – 如何在不同的时区渲染日期?

发布时间:2020-12-13 16:38:33 所属栏目:百科 来源:网络整理
导读:我的服务器在中央时间。我想使用东部时间渲染时间戳。 例如,我希望2012-05-29 15:00:00作为2012-05-29 16:00:00 EDT。 我该如何实现? to_char(‘2012-05-29 15:00:00′::时区’EST5EDT’上的timestamptz’,’YYYY-MM-DD HH24:MI:SS TZ’)给出2012-05-29
我的服务器在中央时间。我想使用东部时间渲染时间戳。

例如,我希望2012-05-29 15:00:00作为2012-05-29 16:00:00 EDT。

我该如何实现?

to_char(‘2012-05-29 15:00:00′::时区’EST5EDT’上的timestamptz’,’YYYY-MM-DD HH24:MI:SS TZ’)给出2012-05-29 16:00:00无区域)。

to_char(‘2012-05-29 15:00:00′::时区’EST5EDT’,’YYYY-MM-DD HH24:MI:SS TZ’)给出2012-05-29 14:00:00 CDT (错误)。

这是一个很好的工作,但它是如此荒唐复杂,必须有一个更简单的方法:replace(replace(to_char((‘2012-05-29 15:00:00′:: timestamptz at time zone’EST5EDT’):: timestamptz’ YYYY-MM-DD HH24:MI:SS TZ’),’CST’,’EST’),’CDT’,’EDT’)

关键是在交易期间将本地时区切换到所需的显示时区:
begin;
set local timezone to 'EST5EDT';
select to_char('2012-05-29 15:00:00'::timestamp at time zone 'CDT','YYYY-MM-DD HH24:MI:SS TZ');
end;

结果是:

2012-05-29 16:00:00 EDT

请注意,使用set [local]时区需要使用全时区名称而不是缩写(例如,CST将不起作用)。查看pg_timezone_names视图中的有效选择。

要在类似于to_char()调用的上下文中使用该方法,我相信此函数执行该作业:

CREATE FUNCTION display_in_other_tz(
      in_t timestamptz,in_tzname text,in_fmt text) RETURNS text
AS $$
DECLARE
 v text;
 save_tz text;
BEGIN
  SHOW timezone into save_tz;
  EXECUTE 'SET local timezone to ' || quote_literal(in_tzname);
  SELECT to_char(in_t,in_fmt) INTO v;
  EXECUTE 'SET local timezone to ' || quote_literal(save_tz);
  RETURN v;
END;
$$ language plpgsql;

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读