oracle数据库中循环同义词,怎么处理

oracle数据库中循环同义词,怎么处理,第1张

1、 当用程序连接或者用plsql查询同义词时,如果出现ora-01775:同义词的循环链这样的问题。

一般是因为存在同义词,但同义词没有相应的对象

2、 先查有没有循环的同义词。

select * from dba_synonyms

where table_owner='TEST'

and synonym_name<>table_name

没有记录。

3、 再查同义词没有对象的数据库对象

select * from dba_synonyms

where table_owner='TEST'

and

synonym_name in

(select a.synonym_name from dba_synonyms a where a.table_owner='TEST'

minus

select object_name from user_objects)

4、 把查询出来的结果进行查询表

select * from DRILL_PRESON

如果该同义词没有相应的对象,则会包ora-01775的错误

5、 把这个同义词删除

drop public synonym DRILL_PRESON

【十四】同义词

14.1 作用

从字面上理解就是别名的意思,和视图的功能类似,就是一种映射关系。

14.2公有同义词

同义词通常是数据库对象的别名;公有同义词一般由DBA创建,使所有用户都可使用;创建者需要create public synonym权限。

示例:

14.3私有同义词

一般是普通用户自己建立的同义词,创建者需要create synonym 权限。

查看同义词的视图:dba_synonyms

删除私有同义词:drop synonym 同义词名

删除公有同义词:drop public synonym 同义词名

14.3 同义词的要点

1)私有同义词是模式对象,一般在自己的模式中使用,如其他模式使用则必须用模式名前缀限定。

2)公有同义词不是模式对象,不能用模式名做前缀。

3)私有和公有同义词同名时,如果指向不同的对象,私有同义词优先。

4)引用的同义词的对象(表或视图)被删除了,同义词仍然存在,这同视图类似,重新创建该对象名,下次访问同义词时自动编译。

the end !!!

@jackman 共筑美好!


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

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-28
下一篇 2023-03-28

发表评论

登录后才能评论

评论列表(0条)

保存