之间有区别吗:
CREATE TABLE p(
product_no integer,
name text UNIQUE,
price numeric
);
and:
CREATE TABLE p(
product_no integer,
name text,
price numeric
);
CREATE UNIQUE INDEX customername
ON p
USING btree
(name COLLATE pg_catalog."default");
在这两种情况下名称都是唯一的吗?当索引唯一时意味着什么?
EDIT: Postgres 唯一约束与索引 https://stackoverflow.com/questions/23542794/postgres-unique-constraint-vs-index没有回答我的问题。它考虑了 FK 的情况。我的问题与FK无关。我只是想知道这两个操作是否等效在这个例子中其中不涉及 FK。
是的,有一点差别。如果你定义了一个唯一的约束它在目录中可见,例如information_schema
。对于唯一索引则不然。
此外,您可以创建部分唯一索引之类的内容,但不能在约束上执行此操作。
最后,唯一约束是 SQL 标准的。
唯一的约束implies创建唯一索引,但反之则不然。
除非您有充分的理由直接创建唯一索引,否则请使用唯一约束。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)