当前位置 > 主页 > 万和大讲堂 >


浅谈Oracle同义词创建及其作用_南京OCA培训

2015-09-24 10:46

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


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


  1、Oracle同义词的分类


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


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


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


  2、关于错误:同义词转换不再有效


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


  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) 为用户简化sql语句。上面的一条其实就是一种简化sql的体现,同时如果自己建的表的名字很长,可以为这个表创建一个Oracle同义词来简化sql开发。南京Oracle认证培训


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


  (3) 为分布式数据库的远程对象提供位置透明性。 南京Oracle认证培训


最近开班 more>
  • 全栈开发
  • 软件测试
  • Java大数据开发工程师
  • Web前端开发
  • 开发课程基础班第三期
  • 开发课程基础班第二期
  • 开发课程基础班第一期
  • Java Web UI Python
  • CISP
  • HCIE-Cloud lab
  • HCIE-Datacom(HCIA,HCIP基础)
  • HCIP-Datacom(HCIA基础)
  • HCIA-Datacom(0基础)
  • HCIE-Datacom(HCIA,HCIP基础)
  • HCIP-Datacom(HCIA基础)
  • HCIA-Datacom(0基础)
  • OCP 19C
  • RHCA-OpenStack
  • 脱产班
  • 脱产班
  • 脱产班
  • 脱产班
  • 脱产班
  • 脱产班
  • 脱产班
  • vip班
  • 双休班
  • 双休班
  • 脱产班
  • 脱产班
  • 脱产班
  • 双休班
  • 双休班
  • 双休班
  • 业余班
  • 业余班
  • 6月28日
  • 6月5日
  • 6月26日
  • 6月27日
  • 6月19日
  • 6月12日
  • 6月5日
  • 随时开课
  • 6月10日
  • 6月4日
  • 6月4日
  • 6月12日
  • 6月26日
  • 6月10日
  • 6月10日
  • 6月4日
  • 7月8日
  • 6月28日
    • 姓 名 :
    • 电 话 :
    • 课 程 :

技术交流群

  • Java大数据交流群560819979加入
  • Python技术交流群595083299加入
  • Oracle技术交流群595119011加入
  • Web前端技术交流群604697610加入
  • Huawei技术交流群482919361加入
  • Redhat技术交流群587875348加入
  • UI设计技术交流群511649801加入
  • Cisco技术交流群596886705加入
  • IT运维技术交流群605888381加入