oracle 同义词

来源:互联网 发布:游戏鼠标品牌 知乎 编辑:程序博客网 时间:2024/06/14 05:55

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

同义词

  • 同义词创建
    同义词语法:CREATE [PUBLIC] SYNONYM synonym FOR object;
    比如:将用户sivsmgr的sivs_users 创建别名sivs_users
create or replace synonym sivs_users for  sivsmgr.sivs_users;

这样当前用户就可以直接使用 sivs_users 对象了

  • 同义词删除
    drop public synonym sivs_users;

  • 同义词查看
    drop public synonym sivs_users;

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

数据库对象
表、视图、序列、过程、函数、程序包,甚至其它同义词都可以创建同义词

1、同义词:私有同义词、公有同义词。
私有同义词只能被当前模式的用户访问。私有同义词名称不可与当前模式的对象名称相同。要在自身的模式创建私有同义词,
用户必须拥有Create Synonym系统权限。要在其它用户模式创建私有同义词,用户必须拥有Create Any Synonym系统权限。
公有同义词可被所有的数据库用户访问。要创建公有同义词,用户必须拥有Create Public Synonym系统权限。

创建私有同义词语法:
Create [OR REPLACE] SYNONYM [schema.]synonym_name FOR [schema.]object_name;
其中:OR REPLACE表示在同义词存在的情况下替换该同义词。
synonym_name表示要创建的同义词的名称。
object_name指定要为之创建同义词的对象的名称。
示例1:create synonym s_emp for scott.emp;

创建公有同义词语法:
Create PUBLIC SYNONYM synonym_name FOR [schema.]object_name;
示例2:create public synonym emp_syn from scott.emp;

可以查询字典视图User_Synonyms来查看用户所创建的同义词的详细信息

删除同义词语法:Drop Synonym synonym_name; 删除公有同义词加上一个Public
此命令只删除同义词,不会删除对应的表。

0 0
原创粉丝点击