当前位置: 首页 > news >正文

oracle中同义词作用,Oracle同义词创建及其作用

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时就会有错误提示:同义词转换不再有效.当然如果本来有那表后面删除了也会有同样的错误。

相关文章:

  • home.php mod spacecp,DiscuzX3后台getshell详细利用方法图解
  • oracle表级恢复的,12c RMAN 表级恢复
  • linux 查看文件多少m,linux 查询文件大小M为单位
  • linux服务器怎么安装证书,linux服务器证书安装指引
  • linux内核风格,Linux内核编码风格
  • centos 7 linux 内核,如何在Centos 7上升级Linux Kernel(内核)
  • windows和linux下如何查看端口被哪个进程占用,Windows查看端口被哪个进程占用
  • linux 怎么查看哪些端口被占用了,linux 怎么查看那些端口被占用
  • linux重新格式化分区表,linux 分区重新格式化
  • thrift linux java,Thrift, Protocol Buffers installation and Java code howto
  • linux里c语言实现http服务序,c/s模式Linux下用c语言实现发送http请求
  • linux下llt测试技巧,HLT与LLT测试简介
  • Linux系统安装matplotlib,linux – ImportError:没有安装了matplotlib的名为matplotlib的模块...
  • linux+qq+输入法下载官网,续:Linux下安装输入法和QQ软件
  • linux文件io缓冲区,linux下的文件IO缓冲区,及其相关操作
  • 10个最佳ES6特性 ES7与ES8的特性
  • ES2017异步函数现已正式可用
  • ES6--对象的扩展
  • GraphQL学习过程应该是这样的
  • Java 实战开发之spring、logback配置及chrome开发神器(六)
  • MySQL用户中的%到底包不包括localhost?
  • node-glob通配符
  • unity如何实现一个固定宽度的orthagraphic相机
  • 学习Vue.js的五个小例子
  • 一个完整Java Web项目背后的密码
  • ​Kaggle X光肺炎检测比赛第二名方案解析 | CVPR 2020 Workshop
  • "无招胜有招"nbsp;史上最全的互…
  • #pragma multi_compile #pragma shader_feature
  • (06)Hive——正则表达式
  • (a /b)*c的值
  • (阿里云万网)-域名注册购买实名流程
  • (二)springcloud实战之config配置中心
  • (二十四)Flask之flask-session组件
  • (牛客腾讯思维编程题)编码编码分组打印下标题目分析
  • (转)Groupon前传:从10个月的失败作品修改,1个月找到成功
  • (转)负载均衡,回话保持,cookie
  • ./configure,make,make install的作用
  • .NET NPOI导出Excel详解
  • .NET 编写一个可以异步等待循环中任何一个部分的 Awaiter
  • .NET/C# 利用 Walterlv.WeakEvents 高性能地中转一个自定义的弱事件(可让任意 CLR 事件成为弱事件)
  • .NET/C# 推荐一个我设计的缓存类型(适合缓存反射等耗性能的操作,附用法)
  • .NET命名规范和开发约定
  • .net之微信企业号开发(一) 所使用的环境与工具以及准备工作
  • /deep/和 >>>以及 ::v-deep 三者的区别
  • ::前边啥也没有
  • [ Linux ] git工具的基本使用(仓库的构建,提交)
  • [.NET]桃源网络硬盘 v7.4
  • [Android]使用Retrofit进行网络请求
  • [AndroidStudio]_[初级]_[修改虚拟设备镜像文件的存放位置]
  • [CCIE历程]CCIE # 20604
  • [EFI]ASUS EX-B365M-V5 Gold G5400 CPU电脑 Hackintosh 黑苹果引导文件
  • [Excel VBA]单元格区域引用方式的小结
  • [leetcode]Symmetric Tree
  • [linux] 创建用户
  • [Nginx]反向代理Node将3000端口访问转换成80端口