同义词总结


从字面上理解就是别名的意思,和视图的功能类似。就是一种映射关系。
    同义词语法:CREATE [PUBLIC] SYNONYM synonym FOR object;
1.创建同义词语句:
  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
2.删除同义词:
    drop public synonym table_name; 
3.查看所有同义词:
    select * from dba_synonyms 
    同义词拥有如下好处:节省大量的数据库空间,对不同用户的操作同一张表没有多少差别;扩展的数据库的使用范围,能够在不同的数据库用户之间实现无缝交互;同义词可以创建在不同一个数据库服务器上,通过网络实现连接。
知识扩展:数据库对象
   表、视图、序列、过程、函数、程序包,甚至其它同义词都可以创建同义词。
  
   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
   此命令只删除同义词,不会删除对应的表。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值