1 同义词的概念Oracle数据库中提供了同义词管理的功能。同义词是数据库方案对象的一个别名,经常用于简化对象访问和提高对象访问的安全性。在使用同义词时,Oracle数据库将它翻译成对应方案对象的名字。与视图类似,同义词并不占用实际存储空间,只有在数据字典中保存了同义词的定义。在Oracle数据库中的大部分数据库对象,如表、视图、同义词、序列、存储过程、包等等,数据库管理员都可以根据实际情况为他们定义同义词。

同义词,顾名思义就是两个词的意思一样,可以互相替换.那它的作用有哪些呢:一个最明显的目的就是简化sql。如果某个数据库对象的名字太长了,可以创建一个短一点的同义词。就相当于是缩写呗。另外一个目的是隐藏一些对象的信息。比如查找另一个schema中的某个表,需要在表名前加schema名做为前缀,若创建一个同义词就可以隐藏schema信息。

2 Oracle同义词的分类Oracle同义词有两种类型,分别是公用Oracle同义词与私有Oracle同义词

(1)公用Oracle同义词:由一个特殊的用户组Public所拥有。顾名思义,数据库中所有的用户都可以使用公用同义词。公用同义词往往用来标示一些比较普通的数据库对象,这些对象往往大家都需要引用。

(2)私有Oracle同义词:它是跟公用同义词所对应,他是由创建他的用户所有。当然,这个同义词的创建者,可以通过授权控制其他用户是否有权使用属于自己的私有同义词。

3 Oracle同义词创建及删除创建公有Oracle同义词的语法:Create [public] synonym 同义词名称 for [username.]objectName。Drop [public] synonym 删除同义词名称。举个创建私有同义词的例子。

私有同义词只有创建它的用户自己可以用,如果其他schema要用必须得加创建者schema为前缀,这和其他对象是一样的。

创建私有同义词:create synonym arwen for user.table_of_arwen

这样使用select * from user.arwen或select * from user.table_of_arwen是一样的

删除私有同义词:DROP SYNOYM arwen

创建共有同义词:create public synonym arwen for user.table_of_arwen

这样使用select * from arwen即可

注意事项:如果其他schema没有权限查找表table_of_arwen则也不能使用它的同义词去查找的

4 Oracle同义词的作用(1) 多用户协同开发中,可以屏蔽对象的名字及其持有者。如果没有同义词,当操作其他用户的表时,必须通过user名.object名的形式,采用了Oracle同义词之后就可以隐蔽掉user名,当然这里要注意的是:public同义词只是为数据库对象定义了一个公共的别名,其他用户能否通过这个别名访问这个数据库对象,还要看是否已经为这个用户授权。

(2) 为用户简化sql语句。上面的一条其实就是一种简化sql的体现,同时如果自己建的表的名字很长,可以为这个表创建一个Oracle同义词来简化sql开发。

(3)为分布式数据库的远程对象提供位置透明性。

5 关于错误:同义词转换不再有效当创建同义词时不会检查同义词代表的对象是否存在,都会成功创建.比如CREATE PUBLIC SYNONYM arwen FOR no_table_exist。若不存在一个表叫no_table_exist或者其他数据库对象叫这名。则SELECT * FROM arwen时就会有错误提示:同义词转换不再有效.当然如果本来有那表后面删除了也会有同样的错误。

oracle中同义词作用,Oracle同义词创建及其作用相关推荐

  1. Oracle中的序列,同义词

    Oracle中的序列,同义词 2006年08月18日 星期五 下午 01:51 什么叫序列:     1:定义:         仅向前的数字变量(和SQL中的自动编号有点像 identity(1,2 ...

  2. Oracle中的视图和同义词

    视图 视图其实就是一条查询sql语句,用于显示一个或多个表或其他视图中的相关数据.视图将一个查询的结果作为一个表来使用,因此视图可以被看作是存储的查询或一个虚拟表.视图来源于表,所有对视图数据的修改最 ...

  3. oracle中LOB字段相关概念(自动创建LOB索引段和重建索引方法)

    OBs,或Large Objects字段,是Oracle中用于处理存储非字符数据推荐的一种字段类型,例如mp3,video,图片,和long字符串数据.二进制大对象,或BLOBs,字符大对象,或CLO ...

  4. oracle中between性能,Oracle中BETWEEN ... AND的作用

    在SQL语句中需要选择两个值之间的数据范围时,通常我们会想到BETWEEN ... AND操作符,例如, SELECT * FROM TABLE WHERE A BETWEEN B AND C; 请问 ...

  5. oracle 中WITH AS,oracle的with as用法

    转自:https://www.cnblogs.com/linjiqin/archive/2013/06/24/3152667.html –针对多个别名 with tmp as (select * fr ...

  6. oracle中rollback用法,Oracle中SAVEPOINT和ROLLBACK用法

    savepoint是事务内部允许部分rollback的标志符.因为事务中对记录做了修改,我们可以在事务中创建savepoint来标识不同的点.如果遇到错误,就可以rollback到不同的点或直接回来事 ...

  7. oracle中call用法,Oracle数据库中 call 和 exec的区别

    Oracle数据库中 call 和 exec的区别 今天发现了一个小东西,觉得很有意思,查找了一些资料,跟大家分享一下: 在sqlplus中: 在第三方提供的工具(如:plsqldev) 总结: ex ...

  8. oracle 中用户 授权,Oracle grant用户授权

    获得对象授权的用户可以访问数据库对象及其内容.提示当用户获得处理其他用户表的权限后,在他能够在SQL语句中引用其他用户的表之前,必须有这些表的公用或私用同义词, Oracle可通过它们识别出这些表. ...

  9. oracle中DBWR全称,Oracle基本术语大全

    Oracle基本术语大全 §2.4.2 重做日志工作模式Oracle可以在两种模式之一来工作: 1)ARCHIVELOG模式(可恢复) Oracle 一般至少有两个日志文件.它们轮流交替地被写入所作的 ...

  10. oracle中各种函数,oracle中常用函数大全

    1.数值型常用函数 函数 返回值 样例 显示 ceil(n) 大于或等于数值n的最小整数 select ceil(10.6) from dual; 11 floor(n) 小于等于数值n的最大整数 s ...

最新文章

  1. java中的基本用法
  2. AS3.0中is,as运算符
  3. DFT - Introduction to Test Models
  4. jsfl 改变舞台宽高
  5. 【ABAP】通过SE30来测试程序的执行效率
  6. python --- opencv部分学习
  7. react学习(48)--编辑回显用moment处理
  8. MapBalanceReduce介绍
  9. [WCF Step by Step 读书笔记] Chapter01 WCF 介绍
  10. CVPR2022 Canonical Voting: Towards Robust Oriented Bounding Box Detectionin 3D Scenes
  11. indoe智能客户端ios_inode客户端证书导入
  12. 并发测试工具(ubuntu 16.04)
  13. robotium android,android自动化测试框架robotium配置和使用
  14. 怎么把Word文档转换成长图
  15. 杂文笔记(一):博弈论在网络安全中的应用
  16. 心电信号系统GUI系统
  17. 做程序员10年有感,程序员必须要懂的---转自java诺曼底_kleen
  18. 循环相乘取整法C语言,华为OJ机试题目:两个大整数相乘(纯C语言实现两个大整数相乘,两种方法实现大数相乘)...
  19. 北大博士生计算机学院任教,当北大博士都去了三流大学任教
  20. python实现推广小项目

热门文章

  1. 贪心算法-会议安排问题
  2. Aerial Cactus Identification(空中仙人掌鉴定)
  3. 如何显示手机gps定位服务器,手机gps定位服务器设置
  4. 基于收益率的基金绩效归因
  5. adb shell 获取手机分辨率
  6. 给学习iOS开发同学的建议
  7. 两球体相交,球缺的计算
  8. 本体技术视点 | 为什么 BIP - 340 选择引入 Schnorr 签名算法?
  9. 利用ACC控制酷狗音乐
  10. 苍天有眼,我终于搞定了win7使用建行华大智宝U盾的问题了!