Oracle DB 同义词

本文介绍如何使用同义词简化数据库对象的访问,包括创建私有和公共同义词的方法及注意事项。

同义词是数据库对象,利用同义词可以通过另一个名称来调用表。可以通过创建同义词来给出表的替代名称。

  • 创建对象的同义词
通过创建同义词(对象的另一个名称)可以简化对对象的访问。使用同义词,你可以:
• 更方便地引用其他用户拥有的表
• 缩短冗长的对象名
CREATE [PUBLI C] SYNONYM synonym FOR    object;

要引用其他用户拥有的表,需要为表名加上一个前缀,即该表的创建者姓名,后跟一个句点。创建同义词后,就不必使用方案来限定对象名了,同时还为你提供了表、视图、序列、过程或其它对象的替代名称。此方法在对象名(例如视图)冗长时特别有用。
在该语法中:
PUBLIC 创建所有用户都可以访问的同义词
synonym 是要创建的同义词的名称
object 标识要为其创建同义词的对象
准则
• 该对象不能包含在程序包中。
• 私用同义词名一定不能与同一用户拥有的其它所有对象的名称相同。
 
私有同义词就是普通用户所创建的同义词,之所以说它是私有同义词是因为只有创建该同义词的用户才能使用此同义词,而公用同义词是指数据库管理员创建的,当然,公用同义词是允许所有的用户来使用的。

  • 创建和删除同义词
• 为DEPT_SUM_VU 视图创建一个简短的名称,目的是为了便于更迅速地进行引用。
CREATE SYNONYM  d_sum FOR  dept_sum_vu;
数据库管理员可以创建所有用户都可以访问的公用同义词。下面的示例为Alice 的DEPARTMENTS 表创建一个名为DEPT 的公用同义词:
CREATE PUBLIC SYNONYM  dept FOR    alice.departments;

• 删除同义词:
DROP SYNONYM d_sum;

要删除同义词,使用DROP SYNONYM语句。

一个用户可以删除自己创建的同义词,如果要删除其他用户创建的同义词,则要具有DROP ANY SYNONYM系统权限。DBA可以删除所有的公共同义词,普通用户需要具有DROP PUBLIC SYNONYM系统权限,才能删除公共同义词。同义词被删除以后,它的相关信息也将从数据字典中删除。

 

数据库管理员可以删除公用同义词
DROP PUBLIC SYNONYM  dept;
### Oracle 创建同义词的语法与示例 在 Oracle 数据库中,创建同义词是为了为数据库对象(如、视图、存储过程、函数、包和序列)提供一个别名,以简化 SQL 语句的书写或跨不同模式/数据库的访问[^2]。 #### 同义词的类型 同义词分为两种类型:公有同义词(PUBLIC SYNONYM)和私有同义词(PRIVATE SYNONYM)。公有同义词可供所有用户访问,而私有同义词仅限于特定模式内的用户访问。 #### 创建同义词的语法 ```sql CREATE [OR REPLACE] [PUBLIC] SYNONYM [schema.]synonym_name FOR [schema.]object_name[@dblink]; ``` - `OR REPLACE`:如果同义词已存在,则替换它。 - `PUBLIC`:指定创建的是公有同义词。 - `schema`:对象所属的模式。如果不指定,则默认为当前用户的模式。 - `synonym_name`:同义词的名称。 - `object_name`:目标数据库对象的名称。 - `@dblink`:可选参数,用于指定远程数据库链接。 #### 示例 1:创建私有同义词 以下示例为 `USER_A.SCOTT_EMP` 创建一个名为 `EMP_ALIAS` 的私有同义词: ```sql CREATE SYNONYM EMP_ALIAS FOR USER_A.SCOTT_EMP; ``` 此操作后,当前用户可以通过 `EMP_ALIAS` 访问 `USER_A.SCOTT_EMP` [^3]。 #### 示例 2:创建公有同义词 以下示例为 `USER_A.SCOTT_EMP` 创建一个名为 `PUBLIC_EMP_ALIAS` 的公有同义词: ```sql CREATE PUBLIC SYNONYM PUBLIC_EMP_ALIAS FOR USER_A.SCOTT_EMP; ``` 此操作后,所有用户都可以通过 `PUBLIC_EMP_ALIAS` 访问 `USER_A.SCOTT_EMP` [^2]。 #### 示例 3:创建指向远程对象的同义词 如果需要创建一个指向远程数据库对象的同义词,可以使用 `@dblink` 参数。例如: ```sql CREATE SYNONYM REMOTE_TABLE_ALIAS FOR USER_A.REMOTE_TABLE@REMOTE_DB; ``` 此操作后,当前用户可以通过 `REMOTE_TABLE_ALIAS` 访问远程数据库中的 `USER_A.REMOTE_TABLE` [^3]。 #### 删除同义词 若要删除同义词,可以使用以下语法: ```sql DROP [PUBLIC] SYNONYM synonym_name; ``` 例如,删除私有同义词 `EMP_ALIAS`: ```sql DROP SYNONYM EMP_ALIAS; ``` 删除公有同义词 `PUBLIC_EMP_ALIAS`: ```sql DROP PUBLIC SYNONYM PUBLIC_EMP_ALIAS; ``` ### 注意事项 - 创建公有同义词需要具有 `CREATE PUBLIC SYNONYM` 权限。 - 删除公有同义词需要具有 `DROP PUBLIC SYNONYM` 权限。 - 如果对象被删除,相关的同义词将变为无效,但不会自动删除。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值