在现在的项目中会有很多接口,数据来源也可能是不同数据库或者是不同的用户下的表,给访问该表带来了一定的麻烦。这个时候就可以使用同义词来简化。
同义词的语法是:CREATE [OR REPLACE] [PUBLIC] SYNONYM [ schema.] 同义词名称 FOR [ schema.] object [ @dblink ];
创建同义词的时候还需要赋值相关的权限:
首先是:用sys账号给DM账号赋予CREATE SYNONYM的权限
GRANT CREATE SYNONYM TO user_temp;
user_temp是你要建同义词的用户。
这个时候你创建同义词的时候,如果找不到你要管理的user_res用户下的表tableA。(注:要在user_temp用户下创建user_res用户下tableA表的同义词)
这个时候还需要一个权限就是user_temp用户select tableA的权限,这个时候是在user_res用户下赋值的
grant select on tableA to user_temp;
这样就可以在user_temp用户下创建同义词了
--Create the synonym
create or replacesynonym tableAfor user_res.tableA;
上面说的是再同一个数据库中,不同用户下创建同义词,当然同义词可以在不同的数据库之间创建,需要创建link。也可以创建私有同义词等等。下面是我记录大神详细整理的同义词相关(来源:http://www.cnblogs.com/kerrycode/archive/2012/12/19/2824963.html 作者:潇湘隐者)。
同义词概念
Oracle的同义词(synonyms)从字面上理解就是别名的意思,和视图的功能类似,就是一种映射关系。它可以节省大量的数据库空间,对不同用户的操作同一张表没有多少差别;它扩展了数据库的使用范围,能够在不同的数据库用户之间实现无缝交互;Oracle数据库中提供了同义词管理的功能。同义词是数据库对象的一个别名,经常用于简化对象访问和提高对象访问的安全性。在使用同义词时,Oracle数据库将它翻译成对应方案对象的名字。与视图类似,同义词并不占用实际存储空间,只有在数据字典中保存了同义词的定义。在Oracle数据库中的大部分数据库对象,如表、视图、物化视图、序列、函数、存储过程、包、同义词等等,数据库管理员都可以根据实际情况为他们定义同义词。
同义词分类
Oracle同义词有两种类型,