同义词是一种数据库对象,它是为一个数据库对象定义的别名,使用同义词的主要目的是为了简化SQL语句的书写。

同义词的概念和类型

利用同义词可以为用户的一个对象,或者其他用户的一个对象定义别名,从而简化命令或程序的书写,在命令或程序中可以直接使用同义词代替原来的对象。

可以为表、视图、存储程序、序列等对象建立同义词,也可以为一个同义词再建立同义词,甚至可以为一个不存在的对象建立同义词,系统仅仅在使用同义词时才验证它所代表的对象是否存在。

同义词本身并不包含原对象中的数据或代码,它的作用仅仅相当于一个指针。

在使用同义词时,系统根据同义词的定义查找它所指向的对象,将对同义词的访问转化为对原对象的访问。

同义词的作用仅仅是为了方便用户操作数据库对象。

Oracle支持两种类型的同义词,即私有同义词和公共同义词。

私有同义词由普通用户创建,在默认情况下只能由用户本人使用。

公有同义词一般由DBA创建,可以由所有用户使用。

公共同义词的意义在于它代表了一个大家都可以访问的对象。

注:普通用户如果要访问公有同义词,需要具有对同义词所指向的原对象的访问权限。

一般来说,在具有相关数据库对象的权限后,即可进行相关的操作,但如果定义了同义词,就可以简化SQL语句的书写。

比如在访问其他用户模式下的数据库对象时,便可以省略对象前的模式名称。

用户可以随意为其他用户的一个对象创建一个同义词,但这并不意味着这个用户就具有了访问其他用户的对象的权限。

因为正如前面所提到的,只有在使用同义词时,系统才验证用户是否有相应的访问权限。

例如:

create synonym emp for scott.emp;

select * from emp;

注:以普通用户身份在scott用户模式下为数据库对象emp创建同义词emp。

在没有访问权限的情况下,提示错误:ORA-00942: 表或视图不存在。

在考虑另一种情况,就是为不存在的对象创建同义词:

create synonym em for scott.em;

select * from em;

在使用同义词em访问源对象时,提示错误:ORA-00980: 同义词转换不再有效。

同义词的创建和删除

用户可以在自己的模式中创建同义词,这时需要具有CREATE SYNONYM这个系统权限。

如果希望在其他用户的模式中创建同义词,则需要具有CREATE ANY SYNONYM这个系统权限。

普通用户如果希望创建公有同义词,需要具有CREATE PUBLIC SYNONYM系统权限。

创建私有同义词的命令是CREATE SYNONYM ,它的语法规则为:

CREATE SYNONYM 同义词 FOR 用户名.对象名;

创建公有同义词的语法格式为:

CREATE SYNONYM 同义词 FOR 用户名.对象名;

注:这里的用户名.对象名是指其他用户模式,因为一般在创建同义词时,是为了方便访问其他用户模式下的对象。

当然也可以在自己模式下创建同义词,对于普通用户而言,如果是创建私有同义词是没有什么意义的。

对于公有同义词而言,普通用户和DBA权限用户都可以在自己用户模式下,创建公有同义词,这样可以方便其他用户对该数据库对象的访问。

比如DBA权限用户创建v$开头的有关动态性能视图的公有同义词。

用户如果不使用同义词时,可以将其删除。

删除同义词的命令是DROP SYNONYM,这条命令的语法格式为:

DROP SYNONYM 同义词名;

注:如果要删除公有同义词的话,要在关键字SYNONYM之前加上关键字PUBLIC。

一个用户可以删除自己创建的同义词,如果要删除其他用户创建的同义词,则要具有DROP ANY SYNONYM 系统权限。

DBA 可以删除所有的公共同义词,普通用户需要具有DROP PUBLIC SYNONYM系统权限,才能删除公共同义词。

同义词被删除以后,它的相关信息也将从数据字典中删除。

注:对于普通用户而言,即使是自己创建的公有同义词,仍需要具有DROP PUBLIC SYNONYM系统权限,才能删除自己创建的同义词。

同义词信息的查询

同义词作为一种数据库对象,它的相关信息被存储在数据字典中。

与同义词有关的数据字典有三个: user_synonyms 、all_synonyms 、dba_synonyms。

其中在数据字典user_synonyms 中记录了当前用户所拥有的同义词。这个表的各列定义及其意义如下所示:

SYNONYM_NAME 同义词名称

TABLE_OWNER 所指向的对象属主

TABLE_NAME 所指向对象的名称

DB_LINK 数据库链接

注:DB_LINK 列是指在创建同义词SYNONYM时,TABLE_NAME 是通过DBLINK获得的。

如果要查询当前用户创建了哪些同义词,它们各代表哪个用户的哪个对象,可以执行下面的SELECT语句进行查询:

SELECT synonym_name, table_owner, table_name FROM user_synonyms;

在数据字典all_synonyms 中记录了当前用户所能使用的所有同义词,包括私有同义词和公共同义词。

在数据字典dba_synonyms 中记录了数据库中所有的同义词,包括每个用户创建的私有同义词和DBA 创建的公共同义词。

这个视图只有DBA 能够访问,它的结构除了包含数据字典user synonyms的所有列外,还有一个列owner代表同义词的创建者。

如果要在整个数据库范围内查询某个同义词的信息,可以对数据字典dba_synonyms进行查询。

例如,要查询用户scott所创建的所有同义词,可以执行下面的SELECT语句:

SELECT synonym_name, table_owner, table_name FROM dba_synonyms WHERE owner='SCOTT';

如果要查询用户scott的表dept具有哪些同义词,可以执行下面的SELECT语句:

SELECT synonym_name, table_owner FROM dba_synonyms WHERE owner='SCOTT' AND table_name='EMP';

如果要查询系统中所有的公共同义词,可以执行下面的SELECT语句:

SELECT synonym_name, table_owner FROM dba_synonyms WHERE owner='PUBLIC';

注:table_owner和owner之前的区别:

table_owner是指同义词所指向数据库对象的属主,一般就是指该对象的创建者,而owner是指同义词的创建者。

oracle 对象同义词,Oracle数据库对象_同义词相关推荐

  1. Oracle事务和常用数据库对象

    1.事务:有一组命令组成的逻辑单元,保证所有操作要么全部成功要么全部失败. 以下情况事务结束:1)显式提交(commit) 2)显式回滚(rollback) 3)ddl语句隐身提交 4)正常结束程序提 ...

  2. 查询mysql所有对象_Mysql查看数据库对象(SQL命令总结)

    标签:Mysql查看数据库对象(SQL命令总结) 数据的对象包括表,视图,触发器,等等(查看统计信息的必须进入information_schema 数据库) 举例查看表相关的信息,步骤如下 1.使用i ...

  3. oracle sql 导入mysql数据库备份_使用PL/SQL连接oracle数据库,并将数据进行导出备份和导入恢复...

    使用PL/SQL连接oracle数据库,并将数据进行导出备份和导入恢复 这种操作百度一搜一大片,今天整理以前做的项目时自己备份了一下数据库,试着将数据进行导出备份和导入恢复了一下:下面是操作过程: 1 ...

  4. Oracle Class4. 数据库对象(同义词,序列,视图,索引,簇)

    ------------------------2013-5-9------------------------ 索引的建立情况:经常用于查询,排序和分组的列(即经常在where,order或grou ...

  5. 【C/C++9】天气APP:Oracle的虚表/日期/序列,索引/视图/链路/同义词,数据库高可用性

    文章目录 1.虚表/日期/序列:SEQUENCE 2.索引/视图/链路/同义词:create index/view/link/synonym 3.表空间/数据文件/启动关闭/权限/备份恢复:exp/i ...

  6. oracle mysql 同义词_Oracle数据库创建同义词(synonym)详细讲解

    1.1数据库创建同义词(synonym) Oracle的同义词(synonyms)从字面上理解就是别名的意思,和视图的功能类似,就是一种映射关系.它可以节省大量的数据库空间,对不同用户的操作同一张表没 ...

  7. oracle 查询公有同义词,Oracle序列(sequence),OracleRUNNUM和Oracle同义词(synonyms)

    一团网资讯 一团资讯 > oracle > Oracle序列(sequence),OracleRUNNUM和Oracle同义词(synonyms)... Oracle序列(sequence ...

  8. sql重命名数据库_为什么要为SQL单元测试巧妙地命名数据库对象

    sql重命名数据库 This article is focussed on clever database object naming from both development and SQL un ...

  9. 鸿蒙对象关系映射数据库

    对象关系映射数据库 对象关系映射数据库简介 对象关系映射数据库存储开发步骤 1.添加配置 2.数据库的创建 3.数据表(实体对象类)的创建 4.使用对象数据操作接口OrmContext创建数据库 5. ...

  10. Oracle数据库对象,同义词、序列、视图、索引

    数据库对象简介 Oracle 数据库对象又称模式对象 数据库对象是逻辑结构的集合,最基本的数据库对象是表 其他数据库对象包括: 同义词是现有对象的一个别名. 简化SQL语句 隐藏对象的名称和所有者 提 ...

最新文章

  1. Redis实现广告缓存、并完善缓存击穿
  2. javascript随机生成GUID
  3. oracle12数据库安装步骤,ORACLE RAC 12C(12.2.0.1)数据库软件安装步骤
  4. react 按照一级路由 分包加载
  5. Java中创建String的两道面试题及详解
  6. 当当网新用户注册界面——界面源码
  7. flutter 国际化_Flutter 开发实战资源推荐
  8. HashMap30连问,彻底搞懂HashMap
  9. Vue移动端项目——搜索联想建议功能的实现(结合watch属性和使用lodash防抖节流)
  10. Shell脚本——入门
  11. Linux下限制用户通过SFTP访问指定目录
  12. 《SQL Server 必知必会》读书笔记
  13. GIMP教程 2 文字工具
  14. win10网络共享计算机名,手把手教你win10一键共享局域网的具体解决步骤
  15. 技术分享| Sip与WebRTC互通-SRProxy开源库讲解
  16. 千兆网线和百兆网线的区别
  17. 印第安纳大学计算机与信息学院,印第安纳大学伯明顿分校管理信息系统(MIS)专业详解...
  18. CommonAPI编写代码
  19. bootstrap3 文件上传插件fileinput中文说明文档
  20. Java session write

热门文章

  1. 网站SEO提升关键词排名的六个步骤
  2. C-COT 【目标跟踪】个人理解
  3. python音频转文字腾讯_Python生成腾讯云实时音视频的UserSig签名
  4. excel 复选框 制作动态表格
  5. Python实现文件/文件夹名按字符串排序或者按数字排序
  6. 面对tomatserver使用的webrequest
  7. 贝尔商道赚钱思维36道第04道:二八定律,约仅有20%的因素影响80%的结果
  8. 最好的黄金技术指标250均线用法
  9. 什么是DTC?为什么国内外如此火爆
  10. Linux运维学习历程-第一天-基础知识