加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

postgresql – 如何将整数转换为序列号

发布时间:2020-12-13 16:36:28 所属栏目:百科 来源:网络整理
导读:我有一个主键列“gid”的表,它的类型是“整数NOT NULL”。 我想将其转换为“Serial NOT NULL”,以便我可以在这个表中插入一些值。 我使用以下命令将其转换成串行: CREATE SEQUENCE test_table_gid_seq INCREMENT 1 MINVALUE 1 MAXVALUE 2147483648 START
我有一个主键列“gid”的表,它的类型是“整数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;

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读