微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

database – 为什么两个表不能有同名的索引?

我在同一个数据库(Postgresql)中的两个单独的表上创建索引,并且我得到一个错误,指出索引已经存在.这是真的,但是,索引存在于另一个表中.更改名称后,它工作.

我想知道为什么会这样?为什么数据库设计为两个表不能具有相同的索引名称

虽然答案不同,但我找到了两个回答这个问题的消息来源.一个用于MySQL,另一个用于Postgres:

In postgres how do I add index to existing table?

Same index name for two tables

解决方法

您可以拥有两个同名的索引.他们只是不能在同一架构中.就像你可以有两个同名的表,但不是在同一个模式中.

sandBox=# create schema test;
CREATE SCHEMA
sandBox=# create table public.a (a_id integer not null);
CREATE TABLE
sandBox=# create table test.a (a_id integer not null);
CREATE TABLE
sandBox=# create index a_idx on public.a (a_id);
CREATE INDEX
sandBox=# create index a_idx on test.a (a_id);
CREATE INDEX

这反映了Postgresql设计师的决定. sql标准不涉及创建索引.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐