我有函数,我正在尝试编译并收到错误Error: ORA-00955: name is already used by an existing object
。我真的不知道这个错误,并尝试搜索此问题,但没有找到任何解决方案。我不知道这与任何授权权限相关,但我没有权限问题到我的架构表。
create or replace FUNCTION "AK_CHECK"
-- PUBLIC
(ID Number) RETURN Number
IS
TYPE_ID Number := 0;
SUCCESS Number := 0;
S Number := 0;
BEGIN
SELECT ACTIVE(ID) + MANUAL(ID) INTO S FROM DUAL;
CASE S
WHEN 2 THEN
SELECT TYPE INTO TYPE_ID
FROM SALE_SUPPLY KD
WHERE KD.KPI_DEF_ID = ID;
END CASE;
END AK_CHECK;
答案 0 :(得分:10)
您可能有另一个具有相同名称的对象(PERFORM_CHECK
)。
您可以通过查询user_objects
:
select *
from user_objects
where object_name = 'PERFORM_CHECK'
然后删除它(将TYPE_OF_OBJECT
替换为上述查询中对象的类型):
drop TYPE_OF_OBJECT perform_check