注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

饥民2011

一直在搬砖

 
 
 

日志

 
 
 
 

Oracle 同义词(synonym) 简介  

2013-10-04 00:24:53|  分类: Oracle |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

从sql server or sybase 转到oracle既程序猿可能对同义词这个概念有点陌生.


同义词不难理解, 只不过是oracle的对象起个别名罢了.


下面介绍下同义词synonym的用法.


1. 创建同义词的权限

首先如果1个用户要创建同义, 前提是他必须具有 create synonym 的权限.

假如我要用scott帐号来建立同义词, 则必须用sys帐号来给scott分配权限:


  1. SQL> show user;  
  2. USER is "SYS"  
  3. SQL> grant create synonym to scott;  
  4.   
  5. Grant succeeded.  
  6.   
  7. SQL> select * from dba_sys_privs where GRANTEE = 'SCOTT';  
  8.   
  9. GRANTEE                PRIVILEGE                ADM  
  10. ------------------------------ ---------------------------------------- ---  
  11. SCOTT                  CREATE SYNONYM               NO  
  12. SCOTT                  SELECT ANY DICTIONARY            NO  
  13. SCOTT                  UNLIMITED TABLESPACE         NO  
  14.   
  15. SQL>   


2. 为当前用户的对象创建同义词

好了, 这是我们可以用如下语法来创建同义词

create synonym <syn_name> for <object_name>

来创建一个同义词.


举个例子,  我用scott 帐号 为scott的表EMP 的建1个同义词:

  1. SQL> show user;  
  2. USER is "SCOTT"  
  3. SQL> create synonym emp_syn for EMP;  
  4.   
  5. Synonym created.  
  6.   
  7. SQL> select * from user_synonyms;  
  8.   
  9. SYNONYM_NAME               TABLE_OWNER            TABLE_NAME             DB_LINK  
  10. ------------------------------ ------------------------------ ------------------------------ --------------------  
  11. EMP_SYN                SCOTT                  EMP  
  12.   
  13. SQL>   


如上面的例子, 建好同义词, 可以利用试图 user_synonyms 来查看当前帐号的同义词.


那么当前帐号就可以利用同义词 emp_syn 来取代对象名 EMP了.

  1. SQL> desc emp_syn;  
  2.  Name                      Null?    Type  
  3.  ----------------------------------------- -------- ----------------------------  
  4.  EMPNO                     NOT NULL NUMBER(4)  
  5.  ENAME                          VARCHAR2(10)  
  6.  JOB                            VARCHAR2(9)  
  7.  MGR                            NUMBER(4)  
  8.  HIREDATE                       DATE  
  9.  SAL                            NUMBER(7,2)  
  10.  COMM                           NUMBER(7,2)  
  11.  DEPTNO                         NUMBER(2)  
  12.   
  13. SQL>   


接下来我们尝试其他帐号, 看看能不能使用这个同义词.

登陆另1个帐号bill,  bill已经被分配scott.emp  的select 权限:

  1. SQL> show user;  
  2. USER is "BILL"  
  3. SQL> select * from user_tab_privs_recd;  
  4.   
  5. OWNER      TABLE_NAME             GRANTOR            PRIVILEGE                GRA HIE  
  6. ---------- ------------------------------ ------------------------------ ---------------------------------------- --- ---  
  7. SYS    DBA_SOURCE             SYS                SELECT                   NO  NO  
  8. SYS    USER_SOURCE            SCOTT              SELECT                   NO  NO  
  9. SYS    USER_TABLES            SCOTT              SELECT                   NO  NO  
  10. SCOTT      USP_EMP_LIST           SCOTT              EXECUTE                  NO  NO  
  11. SCOTT      EMP                SCOTT              SELECT                   NO  NO  

但是,并不能使用scott 的同义词 emp_syn

  1. SQL> desc scott.emp  
  2.  Name                      Null?    Type  
  3.  ----------------------------------------- -------- ----------------------------  
  4.  EMPNO                     NOT NULL NUMBER(4)  
  5.  ENAME                          VARCHAR2(10)  
  6.  JOB                            VARCHAR2(9)  
  7.  MGR                            NUMBER(4)  
  8.  HIREDATE                       DATE  
  9.  SAL                            NUMBER(7,2)  
  10.  COMM                           NUMBER(7,2)  
  11.  DEPTNO                         NUMBER(2)  
  12.   
  13. SQL> desc emp_syn;  
  14. ERROR:  
  15. ORA-04043: object emp_syn does not exist  
  16.   
  17.   
  18. SQL>   

可见他人并不能使用scott的同义词.

实际上同义词不能由所属用户分配给他人.


例如当然soctt 执行

grant all on emp_syn to xxx

时, 实际山这句话的emp_syn会被编译成 EMP, 分配的实际上是表 emp的权限了.



解决方法就是bill 自己也建1个同义词给scott.emp


3. 给他人对象建立同义词

接上面, 加入我们要用bill来给scott.emp 建同义词.

注意权限, 首先我们要为bill 分配 create synonym 的权限, 这个是肯定的了, 其次bill必须要有scott.emp的select 权限. 也就是必须识别scott.emp.


  1. SQL> conn sys as sysdba;  
  2. Enter password:   
  3. Connected.  
  4. SQL> grant create synonym to bill;  
  5.   
  6. Grant succeeded.  
  7.   
  8. SQL> conn bill  
  9. Enter password:   
  10. ERROR:  
  11. ORA-28002: the password will expire within 6 days  
  12.   
  13.   
  14. Connected.  
  15. SQL> create synonym emp_syn for scott.emp;  
  16.   
  17. Synonym created.  

很简单 注意, 对象名带模式前序.
  评论这张
 
阅读(197)| 评论(0)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017