19 postgresql
我有一个表有一个主键列"gid",其类型是"整数非空".我想将其转换为"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);
Run Code Online (Sandbox Code Playgroud)
此命令将整数转换为串行.但是当我在发生错误后向表中输入一些数据时:
错误:重复键值违反唯一约束"pk_test".
请帮我解决这个问题.有没有其他方法可以将整数转换为串行?
drn*_*gis 25
选择gid列的最大值(max_gid):
SELECT max(gid) FROM test_table;
Run Code Online (Sandbox Code Playgroud)
并将其用作序列的起点(可能是max_gid + 1):
ALTER SEQUENCE test_table_gid_seq RESTART WITH max_gid;
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
11381 次 |
| 最近记录: |