225

タイプの列があり、TIMESTAMP WITHOUT TIME ZONEそのデフォルトを UTC の現在の時刻にしたいと考えています。UTC で現在時刻を取得するのは簡単です。

postgres=# select now() at time zone 'utc';
          timezone          
----------------------------
 2013-05-17 12:52:51.337466
(1 row)

列の現在のタイムスタンプをそのまま使用します。

postgres=# create temporary table test(id int, ts timestamp without time zone default current_timestamp);
CREATE TABLE
postgres=# insert into test values (1) returning ts;
             ts             
----------------------------
 2013-05-17 14:54:33.072725
(1 row)

しかし、それは現地時間を使用します。それを UTC に強制しようとすると、構文エラーが発生します。

postgres=# create temporary table test(id int, ts timestamp without time zone default now() at time zone 'utc');
ERROR:  syntax error at or near "at"
LINE 1: ...int, ts timestamp without time zone default now() at time zo...
4

6 に答える 6

3

関数は既に存在します: timezone('UTC'::text, now())

于 2018-08-22T11:26:42.107 に答える