索引还可以用于强制列值的唯一性,或者多个列的组合值的唯一性。
CREATE UNIQUE INDEXname
ONtable
(column
[, ...]) [ NULLS [ NOT ] DISTINCT ];
目前,只有 B 树索引可以声明为唯一。
当一个索引被声明为唯一时,不允许存在多个具有相等索引值的表行。默认情况下,唯一列中的空值不被认为是相等的,允许列中存在多个空值。NULLS NOT DISTINCT
选项会修改此行为,并使索引将空值视为相等。多列唯一索引只会拒绝多个行中所有索引列都相等的情况。
当为表定义唯一约束或主键时,PostgreSQL 会自动创建唯一索引。该索引覆盖构成主键或唯一约束的列(如果适用,则为多列索引),并且是强制执行约束的机制。
无需手动在唯一列上创建索引;这样做只会重复自动创建的索引。
如果您在文档中发现任何不正确、与您使用特定功能的体验不符或需要进一步澄清的内容,请使用此表单报告文档问题。