SQL之同义词

SQL之同义词,第1张

【十四】同义词

14.1 作用

从字面上理解就是别名的意思,和视图的功能类似,就是一种映射关系。

14.2公有同义词

同义词通常是数据库对象的别名;公有同义词一般由DBA创建,使所有用户都可使用;创建者需要create public synonym权限。

示例:

14.3私有同义词

一般是普通用户自己建立的同义词,创建者需要create synonym 权限。

查看同义词的视图:dba_synonyms

删除私有同义词:drop synonym 同义词名

删除公有同义词:drop public synonym 同义词名

14.3 同义词的要点

1)私有同义词是模式对象,一般在自己的模式中使用,如其他模式使用则必须用模式名前缀限定。

2)公有同义词不是模式对象,不能用模式名做前缀。

3)私有和公有同义词同名时,如果指向不同的对象,私有同义词优先。

4)引用的同义词的对象(表或视图)被删除了,同义词仍然存在,这同视图类似,重新创建该对象名,下次访问同义词时自动编译。

the end !!!

@jackman 共筑美好!

可以除去对象名必须带的方案限制,并提供一个可替换的对象名,对具有特别长的对象的名字特别有用。

CREATE SYNONYM 同义词名 FOR 对象名

同义词表 user_synonyms

DROP SYNONYM 同义词名

CREATE [PUBLIC]SYNONYM synonym For schema.object

隐藏对象的名称和所有者:

select count(*) from hr.employees

create synonym emp for hr.employees

--默认属于donny用户,是donny的私有对象private

select count(*) from emp

为分布式数据库的远程对象提供了位置透明性:

访问其他数据库时,要首先建立数据库连结:

CREATE DATABASE LINK test_link CONNECT TO username IDENTIFIED BY pass USING 'orabase'

Select count(*) from hr.employees@test_link

create synonym link_emp for hr.employees@test_link

select count(*) from link_emp

提供对象的公共访问:

create public synonym pub_emp for hr.employees

pub_emp属于public用户,数据库所有用户都可以访问。

同义词类型

–私有 emp

实际上donny.emp

–公用 pub_emp

所有用户都可以直接访问

当公有对象和私有对象同名时(因为数据不同的用户,所以可以),以私有对象优先。(类似于局部变量)

desc

dba_synonyms/ user_synonyms/ all_synonyms 数据字典,复数

tab公有同义词

建立私有的tab表,查看效果。

删除同义词:

drop synonym donny.emp

drop public synonym pub_emp


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/6906039.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-30
下一篇 2023-03-30

发表评论

登录后才能评论

评论列表(0条)

保存