支持的版本:当前 (16) / 15 / 14 / 13 / 12
开发版本:devel
不受支持的版本:11 / 10 / 9.6 / 9.5 / 9.4 / 9.3 / 9.2 / 9.1 / 9.0 / 8.4 / 8.3 / 8.2 / 8.1 / 8.0 / 7.4 / 7.3 / 7.2

11.6. 唯一索引 #

索引还可以用来强制列值的唯一性,或多个列的组合值的唯一性。

CREATE UNIQUE INDEX name ON table (column [, ...]) [ NULLS [ NOT ] DISTINCT ];

目前,只有 B 树索引可以声明为唯一。

当索引声明为唯一时,不允许表中有多个具有相等索引值的行。默认情况下,唯一列中的空值不被视为相等,允许列中有多个空值。NULLS NOT DISTINCT 选项修改了这一点,并导致索引将空值视为相等。多列唯一索引只会拒绝在多行中所有索引列都相等的情况。

PostgreSQL 在为表定义唯一约束或主键时自动创建一个唯一索引。该索引涵盖构成主键或唯一约束的列(如果合适,则为多列索引),并且是强制约束的机制。

注意

无需在唯一列上手动创建索引;这样做只会复制自动创建的索引。

提交更正

如果您在文档中看到任何不正确、与您对特定功能的体验不符或需要进一步澄清的内容,请使用 此表单 报告文档问题。