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