oracle的同义词

概述
同义词是表、索引、视图或者其他模式对象的一个别名。同义词只是数据库对象的一个替代名,在使用同义词的时候,oracle简单的将它翻译为对应的基础数据对象的名称。oracle只在数据字典中保存同义词的定义描述,因此同义词并不占用任何实际的存储空间。

在以下的场景中DBA可以考虑建同义词:
1:为重要的数据库对象创建同义词,以便隐藏对象的实际名称;
2:在分布式数据库系统中,为存储在远程库中的对象创建同义词,使用户可以像使用本地对象一样对远程对象进行操作;
3:为名称很长或者很复杂的数据库对象创建同义词,以简化SQL语句。

在oracle中,同义词分为两类:
1:公有同义词。公有同义词由一个特殊的用户组PUBLIC所拥有,数据库中所有的用户都可以使用公有同义词。
2:私有同义词。由创建它的用户(或模式)所拥有。

创建同义词语句

create public synonym table_name for user.table_name;

其中第一个user_table和第二个user_table可以不一样。

此外如果要创建一个远程的数据库上的某张表的同义词,需要先创建一个Database Link(数据库连接)来扩展访问,然后在使用如下语句创建数据库同义词:create synonym table_name for table_name@DB_Link;

当然,你可能需要在user用户中给当前用户(user2)授权: grant select/delete/update on user2

删除同义词

drop public synonym table_name;

查看所有同义词

select * from dba_synonyms;

同义词拥有如下好处:
节省大量的数据库空间,对不同用户的操作同一张表没有多少差别;
扩展的数据库的使用范围,能够在不同的数据库用户之间实现无缝交互;
同义词可以创建在不同的数据库服务器上,通过网络实现连接。

此条目发表在mysql/oracle/postgresql分类目录,贴了, 标签。将固定链接加入收藏夹。

发表评论

您的电子邮箱地址不会被公开。

此站点使用Akismet来减少垃圾评论。了解我们如何处理您的评论数据