我ALTER COLUMN
在PostgreSQL 9.3 ALTER TABLE
手册页中找到了这个语句:
ALTER TABLE audits ALTER COLUMN created_at SET DATA TYPE timestamp with time zone USING timestamp with time zone 'epoch' + created_at * interval '1 second';
我似乎无法让这个工作.我收到这个错误:
ERROR: operator does not exist: timestamp without time zone * interval SQL state: 42883 Hint: No operator matches the given name and argument type(s). You might need to add explicit type casts.
该ALTER TABLE
声明看起来很直盼着.但我已经尝试了各种类型的转换和转换列类型,但无法使其工作.我错过了什么?
Postgres手册中的示例(以及@mvp的工作小提琴)将integer
列(表示UNIX纪元)转换为timestamptz
.
错误消息以及您的标题清楚地表明您正在尝试将a转换timestamp
为timestamptz
.这只是自动工作,没有明确的演员.
ALTER TABLE test ALTER created_at TYPE timestamptz;
- > SQLfiddle.
有关timestamp与timestamptz的更多信息:
在Rails和PostgreSQL中完全忽略时区
timestamp
值始终根据会话的时区设置进行解释.假设转换的时区UTC:
BEGIN; SET LOCAL timezone='UTC'; ALTER TABLE test ALTER created_at TYPE timestamptz; COMMIT;
或者使用AT TIME ZONE
构造:
ALTER TABLE test ALTER created_at TYPE timestamptz USING created_at AT TIME ZONE 'UTC';
您可以通过这种方式假设任何时区.