11.6. 唯一索引#

11.6. 唯一索引#

11.6. 唯一索引 #

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

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

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

当一个索引被声明为唯一时,不允许具有相同索引值的多行表记录。默认情况下,唯一列中的 NULL 值不被视为相等,因此允许该列中有多个 NULL。 `NULLS NOT DISTINCT` 选项会修改此行为,使索引将 NULL 值视为相等。多列唯一索引只会拒绝多个行中所有索引列都相同的组合。

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

注意

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

相关文章

为什么不让进?大学校园应不应该对社会开放?
365bet在线注册

为什么不让进?大学校园应不应该对社会开放?

📅 08-06 👁️ 5669
购买SSD固态硬盘前你必须了解的相关知识,别被坑了!
365bet平台客户端

购买SSD固态硬盘前你必须了解的相关知识,别被坑了!

📅 10-27 👁️ 7259
阴阳师讲故事的人式神推荐 讲故事的人用什么式神
365bet平台客户端

阴阳师讲故事的人式神推荐 讲故事的人用什么式神

📅 08-07 👁️ 2788