Redrock Postgres 搜索 英文
版本: 9.3 / 9.4 / 9.5 / 9.6 / 10 / 11 / 12 / 13 / 14 / 15 / 16 / 17

11.6. 唯一索引 #

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

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

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

当索引声明为唯一索引时,不允许表中有多行具有相等的已编入索引的值。默认情况下,唯一列中的空值不被视为相等,从而允许列中存在多个空值。NULLS NOT DISTINCT 选项会修改此值,并使索引将空值视为相等。多列唯一索引仅拒绝在多行中所有已编入索引的列均相等的情况。

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

备注

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