Oracle 同义词(synonym) 简介
2013-10-04 00:23
489 查看
从sql server or sybase 转到oracle既程序猿可能对同义词这个概念有点陌生.
同义词不难理解, 只不过是oracle的对象起个别名罢了.
下面介绍下同义词synonym的用法.
假如我要用scott帐号来建立同义词, 则必须用sys帐号来给scott分配权限:
create synonym <syn_name>
for <object_name>
来创建一个同义词.
举个例子, 我用scott 帐号 为scott的表EMP 的建1个同义词:
如上面的例子, 建好同义词, 可以利用试图 user_synonyms 来查看当前帐号的同义词.
那么当前帐号就可以利用同义词 emp_syn 来取代对象名 EMP了.
接下来我们尝试其他帐号, 看看能不能使用这个同义词.
登陆另1个帐号bill, bill已经被分配scott.emp 的select 权限:
但是,并不能使用scott 的同义词 emp_syn
可见他人并不能使用scott的同义词.
实际上同义词不能由所属用户分配给他人.
例如当然soctt 执行
grant all on emp_syn to xxx
时, 实际山这句话的emp_syn会被编译成 EMP, 分配的实际上是表 emp的权限了.
解决方法就是bill 自己也建1个同义词给scott.emp
注意权限, 首先我们要为bill 分配 create synonym 的权限, 这个是肯定的了, 其次bill必须要有scott.emp的select 权限. 也就是必须识别scott.emp.
很简单 注意, 对象名带模式前序.
同义词不难理解, 只不过是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.
很简单 注意, 对象名带模式前序.
相关文章推荐
- msdba
- Oracle默认端口清单
- Oracle undo我们需要掌握什么
- Oracle DB 管理还原数据
- 重新整理oracle学习大纲路线
- 与IO相关的等待事件troubleshooting-系列1
- Oracle 的关联子查询(correlated subquery) 简介.
- cx_Oracle - ImportError: DLL load failed: The specific module could not be found
- oracle using 和on的用法不同处
- oracle decode
- VS2010下访问oracle数据库的OCCI配置
- oracle 削除データの復帰方法(flash back)
- Oracle DB_约束
- Oracle 热备份batch脚本 Windows
- oracle 索引
- maven 管理oracle jar
- Oracle ABP(Autotask Background Process)
- Oracle维护:每天的工作
- oracle 表操作基本命令
- oracle分区