Oracle 同义词(synonym) 简介

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


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


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


1. 创建同义词的权限

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

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


SQL> show user;
USER is "SYS"
SQL> grant create synonym to scott;

Grant succeeded.

SQL> select * from dba_sys_privs where GRANTEE = 'SCOTT';

GRANTEE 		       PRIVILEGE				ADM
------------------------------ ---------------------------------------- ---
SCOTT			       CREATE SYNONYM				NO
SCOTT			       SELECT ANY DICTIONARY			NO
SCOTT			       UNLIMITED TABLESPACE			NO

SQL> 


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

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

create synonym <syn_name> for <object_name>

来创建一个同义词.


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

SQL> show user;
USER is "SCOTT"
SQL> create synonym emp_syn for EMP;

Synonym created.

SQL> select * from user_synonyms;

SYNONYM_NAME		       TABLE_OWNER		      TABLE_NAME		     DB_LINK
------------------------------ ------------------------------ ------------------------------ --------------------
EMP_SYN 		       SCOTT			      EMP

SQL> 


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


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

SQL> desc emp_syn;
 Name					   Null?    Type
 ----------------------------------------- -------- ----------------------------
 EMPNO					   NOT NULL NUMBER(4)
 ENAME						    VARCHAR2(10)
 JOB						    VARCHAR2(9)
 MGR						    NUMBER(4)
 HIREDATE					    DATE
 SAL						    NUMBER(7,2)
 COMM						    NUMBER(7,2)
 DEPTNO 					    NUMBER(2)

SQL> 


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

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

SQL> show user;
USER is "BILL"
SQL> select * from user_tab_privs_recd;

OWNER	   TABLE_NAME			  GRANTOR			 PRIVILEGE				  GRA HIE
---------- ------------------------------ ------------------------------ ---------------------------------------- --- ---
SYS	   DBA_SOURCE			  SYS				 SELECT 				  NO  NO
SYS	   USER_SOURCE			  SCOTT 			 SELECT 				  NO  NO
SYS	   USER_TABLES			  SCOTT 			 SELECT 				  NO  NO
SCOTT	   USP_EMP_LIST 		  SCOTT 			 EXECUTE				  NO  NO
SCOTT	   EMP				  SCOTT 			 SELECT 				  NO  NO

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

SQL> desc scott.emp
 Name					   Null?    Type
 ----------------------------------------- -------- ----------------------------
 EMPNO					   NOT NULL NUMBER(4)
 ENAME						    VARCHAR2(10)
 JOB						    VARCHAR2(9)
 MGR						    NUMBER(4)
 HIREDATE					    DATE
 SAL						    NUMBER(7,2)
 COMM						    NUMBER(7,2)
 DEPTNO 					    NUMBER(2)

SQL> desc emp_syn;
ERROR:
ORA-04043: object emp_syn does not exist


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.


SQL> conn sys as sysdba;
Enter password: 
Connected.
SQL> grant create synonym to bill;

Grant succeeded.

SQL> conn bill
Enter password: 
ERROR:
ORA-28002: the password will expire within 6 days


Connected.
SQL> create synonym emp_syn for scott.emp;

Synonym created.

很简单 注意, 对象名带模式前序.



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

nvd11

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值