【十四】同义词14.1 作用,下面我们就来说一说关于sql的后缀是什么?我们一起去了解并探讨一下这个问题吧!

sql的后缀是什么(SQL之同义词)

sql的后缀是什么

【十四】同义词

14.1 作用

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

14.2公有同义词

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

示例:

SQL>conn / as sysdba SQL>create view v1 as select ename,sal,deptno from scott.emp where deptno=10; SQL>create public synonym syn1 for v1; SQL>grant select on syn1 to public;

14.3私有同义词

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

sys: SQL> grant create synonym to scott; scott: SQL> create synonym abc for emp; scott建立了一个私有同义词 SQL> select * from abc; scott可以使用这个私有同义词了 SQL> grant select on abc to tim; 把访问同义词的对象权限给tim SQL> select * from scott.abc; tim使用同义词时要加模式名前缀

查看同义词的视图:dba_synonyms

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

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

SQL>select * from dba_synonyms where synonym_name='SYN1';

14.3 同义词的要点

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

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

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

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

the end !!!

@jackman 共筑美好!

,