受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: devel

11.6. 唯一索引 #

索引还可以用于强制列值唯一,或者强制多个列组合值唯一。

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

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

当一个索引被声明为唯一时,就不允许存在多个具有相同索引值的表行。默认情况下,唯一列中的空值不被视为相等,因此该列中可以有多个空值。NULLS NOT DISTINCT选项会改变这一点,使索引将空值视为相等。多列唯一索引只会拒绝那种在多行中所有索引列都相等的情况。

当为表定义唯一约束或主键时,PostgreSQL会自动创建一个唯一索引。该索引覆盖构成主键或唯一约束的列(必要时是多列索引),并且正是它在强制执行该约束。

Note

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

提交更正

如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。