加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-13 15:58:33 所属栏目:百科 来源:网络整理
导读:我在同一个数据库(PostgreSQL)中的两个单独的表上创建索引,并且我得到一个错误,指出索引已经存在.这是真的,但是,索引存在于另一个表中.更改名称后,它工作. 我想知道为什么会这样?为什么数据库设计为两个表不能具有相同的索引名称? 虽然答案不同,但我找到了
我在同一个数据库(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标准不涉及创建索引.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读