暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

故障处理|Oracle 如何解决 ORA-01418: 指定的索引不存在

原创 小小亮 2022-10-27
6524

ORA-01418

尝试更改索引,但失败并出现 ORA-01418。

SQL> alter index emp_emp_id_pk rebuild;
alter index emp_emp_id_pk rebuild
*
ERROR at line 1:
ORA-01418: specified index does not exist

ORA-01418 表示 SQL 引擎找不到您指定的索引,您必须验证索引名称或以索引所有者身份登录。

让我们看看当前的用户是什么。

SQL> show user
USER is "OE"

然后我们检查索引的所有者是谁。

SQL> column owner format a10;
SQL> select owner from all_indexes where index_name = 'EMP_EMP_ID_PK';

OWNER
----------
HR

好的,所有者不是当前用户。

解决方案

您有 2 个选项来解决 ORA-01418。

1. 以所有者身份登录

所有者有权更改或重建其索引

SQL> show user
USER is "HR"
SQL> alter index emp_emp_id_pk rebuild;

Index altered.

2. 授予 ALTER ANY INDEX 权限

对于那些想要更改其他索引的人,我们应该授予它ALTER ANY INDEX系统权限。

SQL> show user
USER is "SYSTEM"
SQL> grant alter any index to oe;

Grant succeeded.

让我们看看结果。

SQL> show user
USER is "OE"
SQL> alter index hr.emp_emp_id_pk rebuild;

Index altered.

不要忘记使用所有者名称限定索引名称。


原文标题:How to Resolve ORA-01418: specified index does not exist

原文作者:  Ed Chen

原文链接:https://logic.edchen.org/how-to-resolve-ora-01418-specified-index-does-not-exist/


「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论