如何更改PostgreSQL表并使列唯一?

问题描述 投票:127回答:3

我在PostgreSQL中有一个表,其架构如下所示:

CREATE TABLE "foo_table" (
    "id" serial NOT NULL PRIMARY KEY,
    "permalink" varchar(200) NOT NULL,
    "text" varchar(512) NOT NULL,
    "timestamp" timestamp with time zone NOT NULL
)

现在,我希望通过ALTER-ing表使表中的固定链接唯一。任何人都可以帮我吗?

TIA

sql postgresql unique-constraint
3个回答
218
投票

我从PostgreSQL文档中找到了它,确切的语法是:

ALTER TABLE the_table ADD CONSTRAINT constraint_name UNIQUE (thecolumn);

谢谢Fred


195
投票

或者,让DB使用以下命令自动分配约束名称:

ALTER TABLE foo ADD UNIQUE (thecolumn);

31
投票

也可以创建一个以上列的唯一约束:

ALTER TABLE the_table 
    ADD CONSTRAINT constraint_name UNIQUE (column1, column2);
© www.soinside.com 2019 - 2024. All rights reserved.