作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个表,它有一个主键列“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”。
请帮我解决这个问题。还有其他方法可以将整数转换为序列吗?
最佳答案
选择gid列的最大值(max_gid):
SELECT max(gid) FROM test_table;
并将其用作序列的起点(可能是 max_gid+1):
ALTER SEQUENCE test_table_gid_seq RESTART WITH max_gid;
关于postgresql - 如何将整数转换为序列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12591207/
我是一名优秀的程序员,十分优秀!