我在PostgreSQL 9.3 ALTER TABLE
manual page中找到了这个ALTER COLUMN
语句:
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
陈述看起来非常直接。但我已经尝试了各种类型的转换和转换列类型,但无法使其工作。我错过了什么?
答案 0 :(得分:16)
Postgres手册中的示例(以及@mvp的工作小提琴)将 integer
列(代表UNIX纪元)转换为timestamptz
。
错误消息以及您的标题清楚地表明您正在尝试将timestamp
转换为timestamptz
。这只是自动生效,没有明确的演员。
ALTER TABLE test ALTER created_at TYPE timestamptz;
有关时间戳与时间戳的更多信息:
Ignoring timezones altogether in Rails and 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';
您可以通过这种方式假设任何时区。
答案 1 :(得分:0)
它对我来说很好:SQLFiddle。
我认为你拥有的是SQL客户端缓存数据类型。我有这个问题,直到我重新启动它,并且类型确实改变了。