今天看书,突然想到了同义词,于是就产生了2个问题:
1、如何查看同义词是public还是private;
2、对public和private同义词是否可以重名?
于是针对这两个问题做了个实验:
首先对scott赋予创建同义词的权限:
sys@ORCL> grant create synonym to scott; (创建私有同义词权限)
sys@ORCL> grant create public synonym to scott;(创建公共同义词的权限)
连接数据库:
sys@ORCL> conn scott/tiger;
Connected.
创建表:
scott@ORCL> create table t(id number);
Table created.
接着创建同义词:
scott@ORCL> create or replace synonym tt for t ; --private synonym
Synonym created.
scott@ORCL> create or replace public synonym tt for t; --public synonym
Synonym created.
然后以sys用户查看dba_synonyms
scott@ORCL> conn / as sysdba
Connected.
sys@ORCL> col owner for a10;
sys@ORCL> col synonym_name for a15;
sys@ORCL> col table_name for a15;
sys@ORCL> select owner,synonym_name,table_name
2 from dba_synonyms
3 where table_name='T';
OWNER SYNONYM_NAME TABLE_NAME
---------- --------------- ---------------
SCOTT TT T
PUBLIC TT T
从OWNER列可以看出是public同义词还是private同义词,从SYNONYM_NAME列可以看出public同义词和private同义词名字是可以相同的。
那么Oracle是如何对SQL中的对象名进行解析的呢?顺序是这样的:
1、首先查看发出命令的用户对表或者视图是否存在并且有访问权限
2、如果表或视图不存在,则检查私有同义词
3、如果私有同义词不存在,则访问公共同义词是否存在
4、如果公共同义词仍不存在,Oracle返回消息“ORA-00942 table or view does not exist”.