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

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

概述我在同一个数据库(PostgreSQL)中的两个单独的表上创建索引,并且我得到一个错误,指出索引已经存在.这是真的,但是,索引存在于另一个表中.更改名称后,它工作. 我想知道为什么会这样?为什么数据库设计为两个表不能具有相同的索引名称? 虽然答案不同,但我找到了两个回答这个问题的消息来源.一个用于MySQL,另一个用于Postgres: In postgres how do I add index 我在同一个数据库(Postgresql)中的两个单独的表上创建索引,并且我得到一个错误,指出索引已经存在.这是真的,但是,索引存在于另一个表中.更改名称后,它工作.

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

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

In postgres how do I add index to existing table?

Same index name for two tables

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

sandBox=# create schema test;CREATE SCHEMAsandBox=# create table public.a (a_ID integer not null);CREATE tablesandBox=# create table test.a (a_ID integer not null);CREATE tablesandBox=# create index a_IDx on public.a (a_ID);CREATE INDEXsandBox=# create index a_IDx on test.a (a_ID);CREATE INDEX

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

总结

以上是内存溢出为你收集整理的database – 为什么两个表不能有同名的索引?全部内容,希望文章能够帮你解决database – 为什么两个表不能有同名的索引?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/1160494.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存