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

Kon*_*rus 27 postgresql timezone datetime

我的服务器在中部时间.我想使用东部时间渲染时间戳.

例如,我想呈现2012-05-29 15:00:002012-05-29 16:00:00 EDT.

我怎样才能实现它?

to_char('2012-05-29 15:00:00'::timestamptz at time zone 'EST5EDT', 'YYYY-MM-DD HH24:MI:SS TZ')2012-05-29 16:00:00(没有区域).

to_char('2012-05-29 15:00:00'::timestamp at time zone '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')

Dan*_*ité 35

关键是在事务持续期间将本地时区切换到所需的显示时区:

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;
Run Code Online (Sandbox Code Playgroud)

结果是:

2012-05-29 16:00:00美国东部时间

请注意,使用set [local] timezone它需要使用全时区域名称而不是缩写(例如,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;
Run Code Online (Sandbox Code Playgroud)