oracle- 同义词

什么是同义词

同义词实质上是指定方案对象的一个别名。通过屏蔽对象的名称和所有者以
及对分布式数据库的远程对象提供位置透明性,同义词可以提供一定程度的安全
性。同时,同义词的易用性较好,降低了数据库用户的 SQL 语句复杂度。
同义词允许基对象重命名或者移动,这时,只需对同义词进行重定义,基于同义
词的应用程序可以继续运行而无需修改。
你可以创建公共同义词和私有同义词。其中,公共同义词属于 PUBLIC 特殊
用户组,数据库的所有用户都能访问;而私有同义词包含在特定用户的方案中,
只允许特定用户或者有基对象访问权限的用户进行访问。
同义词本身不涉及安全,当你赋予一个同义词对象权限时,你实质上是在给
同义词的基对象赋予权限,同义词只是基对象的一个别名

创建与使用同义词

语法:

create [public] SYNONYM synooym for object;

其中 synonym 表示要创建的同义词的名称,object 表示表,视图,序列等我们要创建同义词的对象的名称。

案例

私有同义词

为表 T_OWNERS 创建 私有 同义词 名称为 OWNERS

--创建私有同义词
create synonym owner for t_owners;

在这里插入图片描述
使用同义词:

select * from owner;

查询结果如下:
在这里插入图片描述

公有同义词

公有同义词,oracle所有用户登录都可以访问
需求:为表 T_OWNERS 创建( 公有 )同义词 名称为 OWNERS2:

--创建公有同义词

create public synonym OWNERS2 for t_owners;

以另外的用户登陆,也可以使用公有同义词:

select * from OWNERS2 ;

删除同义词

-- 删除私有同义词
drop synonym 同义词名称;
-- 删除公有同义词
drop public synonym  OWNERS2;
### 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` 权限。 - 如果对象被删除,相关的同义词将变为无效,但不会自动删除。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值