Использование текущего времени в UTC в качестве значения по умолчанию в PostgreSQL

У меня есть колонка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...

Ответы на вопрос(6)

Ваш ответ на вопрос