索引还可用于强制一列值的唯一性,或强制多个列的组合值的唯一性。
CREATE UNIQUE INDEX name ON table (column [, ...]);
目前,只有B树索引可以声明为唯一的。
当一个索引被声明为唯一时,不允许有多个索引值相等的表行。空值被认为是不相等的。多列唯一索引只会拒绝所有索引列在多行中相等的情况。
当为表定义唯一约束或主键时,PostgreSQL会自动创建唯一索引。索引包括构成主键或唯一约束的列(如果合适,可以是多列索引),并且是强制约束的机制。
无需在唯一列上手动创建索引;这样做只会复制自动创建的索引。