Oracle的同义词(synonyms)

2022-07-11 15:15:08

Oracle的同义词(synonyms)从字面上理解就是别名的意思,和试图的功能类似,就是一种映射关系。本文介绍如何创建同义词语句,删除同义词以及查看同义词语句。


 


oracle的同义词总结:


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


1.创建同义词语句:


        create public synonym table_name for user.table_name;


其中第一个user_table和第二个user_table可以不一样。(需要第二个用户给创建同义词的用户授予访问权限。例如select/delete/update)


 image.png,例如 AA的同义词,就是指向DI_PLATFORMLIB.AA。 select * from AA==select * from.DI_PLATFORMLIB.AA


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


 


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


 


2.删除同义词:


        drop public synonym table_name;


3.查看所有同义词:


        select * from dba_synonyms


 


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



原文链接:https://blog.csdn.net/ayang722/article/details/76955763