如何将整数转换为串行

时间:2012-09-25 05:25:00

标签: postgresql

我有一个表,其主键列为“gid”,其类型为“Integer NOT NULL”。 我想将其转换为“Serial NOT NULL”,以便我可以在此表中插入一些值。 我使用以下命令将其转换为串行:

CREATE SEQUENCE test_table_gid_seq
        INCREMENT 1
        MINVALUE 1
        MAXVALUE 2147483648 START 1
        CACHE 1;

ALTER TABLE test_table ALTER COLUMN gid
        SET DEFAULT nextval('test_table_gid_seq'::regclass);

此命令将整数转换为串行。但是当我在发生错误后向表中输入一些数据时:

错误:重复键值违反了唯一约束“pk_test”。

请帮我解决这个问题。有没有其他方法可以将整数转换为串行?

1 个答案:

答案 0 :(得分:25)

选择gid列的最大值(max_gid):

SELECT max(gid) FROM test_table;

并将其用作序列的起点(可能是max_gid + 1):

ALTER SEQUENCE test_table_gid_seq RESTART WITH max_gid;