我熟悉 ORA-01775 背后的问题:循环同义词链,但是有什么技巧可以调试它,还是我只需要“创建或替换”我的出路?
有没有办法查询模式或任何东西来找出公共同义词的当前定义是什么?
更棒的是图形工具,但在这一点上,任何东西都会有帮助。
事实证明,问题实际上并不是同义词的循环链,而是同义词指向一个不存在的视图这一事实。
在这种情况下,Oracle 显然会错误地显示为循环链。
如果您使用的是 TOAD,请转到 View>Toad Options>Oracle>General 并从 EXPLAIN PLAN 部分删除 TOAD_PLAN_TABLE 并将 PLAN_TABLE
数据字典表DBA_SYNONYMS
包含有关数据库中所有同义词的信息。所以你可以运行查询
SELECT table_owner, table_name, db_link
FROM dba_synonyms
WHERE owner = 'PUBLIC'
AND synonym_name = <<synonym name>>
查看公共同义词当前指向的内容。
此错误代码的不太直观的解决方案似乎是同义词指向的对象存在问题。
这是我用于查找指向错误对象的同义词的 SQL。
SELECT S.OWNER as SYN_OWNER, S.SYNONYM_NAME as SYN_NAME,
S.TABLE_OWNER as OBJ_OWNER, S.TABLE_NAME as OBJ_NAME,
CASE WHEN O.OWNER is null THEN 'MISSING' ELSE O.STATUS END as OBJ_STATUS
FROM DBA_SYNONYMS S
LEFT JOIN DBA_OBJECTS O ON S.TABLE_OWNER = O.OWNER AND S.TABLE_NAME = O.OBJECT_NAME
WHERE O.OWNER is null
OR O.STATUS != 'VALID';
尝试此选择以查找有问题的同义词,它列出了指向不存在的对象的所有同义词(表、视图、序列、包、过程、函数)
SELECT *
FROM dba_synonyms
WHERE table_owner = 'USER'
AND (
NOT EXISTS (
SELECT *
FROM dba_tables
WHERE dba_synonyms.table_name = dba_tables.TABLE_NAME
)
AND NOT EXISTS (
SELECT *
FROM dba_views
WHERE dba_synonyms.table_name = dba_views.VIEW_NAME
)
AND NOT EXISTS (
SELECT *
FROM dba_sequences
WHERE dba_synonyms.table_name = dba_sequences.sequence_NAME
)
AND NOT EXISTS (
SELECT *
FROM dba_dependencies
WHERE type IN (
'PACKAGE'
,'PROCEDURE'
,'FUNCTION'
)
AND dba_synonyms.table_name = dba_dependencies.NAME
)
)
今天我得到了这个错误,调试后我发现实际的表丢失了,我用同义词指代。所以我建议 - 首先检查表是否存在!:-))
步骤 1)查看名称存在哪些对象:
select * from all_objects where object_name = upper('&object_name');
可能存在同义词但没有表?
第 2 步)如果这不是问题,请调查同义词:
select * from all_synonyms where synonym_name = upper('&synonym_name');
可能是缺少该同义词的基础表或视图?
一位开发人员不小心编写了生成并运行以下 SQL 语句的代码,CREATE OR REPLACE PUBLIC SYNONYM "DUAL" FOR "DUAL";
导致select * from dba_synonyms where table_name = 'DUAL';
返回PUBLIC DUAL SOME_USER DUAL
而不是PUBLIC DUAL SYS DUAL
.
我们能够通过运行修复它(感谢如何重新创建公共同义词“DUAL”?)
ALTER SYSTEM SET "_SYSTEM_TRIG_ENABLED"=FALSE SCOPE=MEMORY;
CREATE OR REPLACE PUBLIC SYNONYM DUAL FOR SYS.DUAL;
ALTER SYSTEM SET "_SYSTEM_TRIG_ENABLED"=true SCOPE=MEMORY;
虽然 Jarrod 的回答是一个好主意,并且发现了更广泛的相关问题,但我发现在 Oracle 论坛中找到的这个查询更直接地解决了(最初陈述的)问题:
select owner, synonym_name, connect_by_iscycle CYCLE
from dba_synonyms
where connect_by_iscycle > 0
connect by nocycle prior table_name = synonym_name
and prior table_owner = owner
union
select 'PUBLIC', synonym_name, 1
from dba_synonyms
where owner = 'PUBLIC'
and table_name = synonym_name
and (table_name, table_owner) not in (select object_name, owner from dba_objects
where object_type != 'SYNONYM')
https://community.oracle.com/message/4176300#4176300
您不必费力地穿过其他类型的无效对象。只是那些实际上处于无限循环中的那些。
我有一个类似的问题,结果是由于表和模式名称中缺少双引号引起的。
我们有同样的 ORA-01775 错误,但在我们的例子中,模式用户在几个公共同义词上缺少一些“授权选择”。
我们今天遇到了这个错误。这就是我们调试和修复它的方式。
由于此错误,包进入无效状态ORA-01775
。
使用错误行号,我们通过package
正文代码找到了试图将数据插入到table
.
table
我们运行下面的查询以检查上述是否synonym
存在。
SELECT * FROM DBA_TABLES WHERE TABLE_NAME = '&TABLE_NAME'; -- No rows returned
SELECT * FROM DBA_SYNONYMS WHERE SYNONYM_NAME = '&SYNONYM_NAME'; -- 1 row returned
由此我们得出结论,需要重新创建该表。由于synonym
指向一个table
不存在的。
DBA 团队重新创建了表,这解决了问题。
ORA-01775: 循环同义词链 当我试图编译一个包时遇到了上述错误,该包正在使用一个为其创建了同义词的对象,但底层对象不可用。
我正在使用以下 sql 在 all_synonyms 中查找 object_name 没有对应对象的条目(在 user_objects 中):
select *
from all_synonyms
where table_owner = 'SCOTT'
and synonym_name not like '%/%'
and table_name not in (
select object_name from user_objects
where object_type in (
'TABLE', 'VIEW', 'PACKAGE', 'SEQUENCE',
'PROCEDURE', 'FUNCTION', 'TYPE'
)
);
http://ora-01775.ora-code.com/建议:
ORA-01775:同义词循环链
原因:通过一系列CREATE同义词语句,定义了一个同义词,指的是它自己。例如,以下定义是循环的:
CREATE SYNONYM s1 for s2 CREATE SYNONYM s2 for s3 CREATE SYNONYM s3 for s1
操作:更改一个同义词定义,使其适用于基表或视图并重试该操作。
如果您正在编译 PROCEDURE,这可能是指在同一 PROCEDURE 中创建时不存在的表或视图。在这种情况下,解决方案是将查询声明为字符串,例如v_query: = 'insert into table select * from table2
,然后立即执行v_query
;
这是因为编译器还不能识别对象,因此找不到引用。问候。
我在错误的模式中定义了一个函数,并且没有公共同义词。即我的proc在模式“Dogs”中,而函数在模式“Cats”中。该函数没有公开的同义词以允许 Dogs 访问猫的函数。
对我来说,表名和同义词都存在,但所有者名称不同。我在与同义词中的所有者名称匹配的所有者名称下重新创建了表。
我使用了@Mahi_0707 发布的查询