9.3 9.4 9.5 9.6 10 11 12 13 14 15
阿里云PostgreSQL 问题报告 纠错本页面

11.6. 唯一索引

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

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

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

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

PostgreSQL会自动为定义了一个唯一约束或主键的表创建一个唯一索引。该索引包含组成主键或唯一约束的所有列(可能是一个多列索引),它也是用于强制这些约束的机制。

注意

不需要手工在唯一列上创建索引,如果那样做也只是重复了自动创建的索引而已。