我有一个主键列“gid”的表,它的类型是“整数NOT NULL”。
我想将其转换为“Serial 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”。
选择gid列的最大值(max_gid):
原文链接:https://www.f2er.com/postgresql/192931.htmlSELECT max(gid) FROM test_table;
并将其用作序列的起点(可能是max_gid 1):
ALTER SEQUENCE test_table_gid_seq RESTART WITH max_gid;