Oracle synonym 同义词

Oracle synonym 同义词,第1张

概述Oracle synonym 同义词   1、Oracle synonym 同义词是数据库当前用户通过给另外一个用户的对象创建一个别名,然后可以通过对别名进行查询和 *** 作,等价于直接 *** 作该数据库对象。   2、Oracle同义词常常是给表、视图、函数、过程、包等制定别名,可以通过CREATE 命令进行创建、ALTER 命令进行修改、DROP 命令执行删除 *** 作。   3、Oracle synonym

Oracle synonym 同义词

  1、Oracle synonym 同义词是数据库当前用户通过给另外一个用户的对象创建一个别名,然后可以通过对别名进行查询和 *** 作,等价于直接 *** 作该数据库对象。

  2、Oracle同义词常常是给表、视图、函数、过程、包等制定别名,可以通过CREATE 命令进行创建、ALTER 命令进行修改、DROP 命令执行删除 *** 作。

  3、Oracle synonym 同义词按照访问权限分为私有同义词、公有同义词。

  4、私有同义词:私有同义词只能当前用户可以访问,前提:当前用户具有create synonym 权限。

  5、公有同义词:公有同义词只能具有DBA用户才能进行创建,所有用户都可以访问的。

语法结构:

  CREATE [OR REPLACE] [PUBliC] SYSNONYM [当前用户.]synonym_nameFOR [其他用户.]object_name;

解析:

  1、create [or replace] 命令create建表命令一样,当当前用户下同义词对象名已经存在的时候,就会删除原来的同义词,用新的同义词替代上。

  2、[public]:创建的是公有同义词,在实际开发过程中比较少用,因为创建就代表着任何用户都可以通过自己用户访问 *** 作该对象,一般我们访问其他用户对象时,需要该用户进行授权给我们。

  3、用户名.object_name:oralce用户对象的权限都是自己用户进行管理的,需要其他用户的某个对象的 *** 作权限,只能通过对象拥有者(用户)进行授权给当前用户。或者当前用户具有系统管理员权限(DBA),即可通过用户名.object_name *** 作该对象。

案例分析:

  我们在school用户下也创建了一张学生信息表(stuinfo),该信息表只存在一个学生信息“张三”。由于我们当前用户student用户不具有school.stuino的权限,因此要需要该用户授权,然后才能访问。

*** 作如下:

  1、--未授权之前查询(提示表不存在,没有 *** 作权限)select * from school.stuinfo;

  2、--登录Jsq_copy用户进行授权 conn school/123456;  grant all on stuinfo to student;

  3、--授权后再次查询该表数据 conn student/123456;  select * from school.stuinfo; 

同义词创建

  我们现在为school.stuinfo创建同义词stuinfo_copy,然后通过当前用户student直接 *** 作同义词stuinfo_copy查询school.stuinfo表数据。

  代码如下:

    create synonym stuinfo_copy for school.stuinfo;

  创建同义词之后,即可使用select *from stuinfo_copy 进行查询,效果等同于select *from school.stuinfo。

同义词删除

  同义词删除只能通过同义词拥有者的用户或者具有DBA权限的用户才能删除。

语法结构:

  DROP [PUBliC] SYNONYM [用户.]sysnonym_name;

总结

以上是内存溢出为你收集整理的Oracle synonym 同义词全部内容,希望文章能够帮你解决Oracle synonym 同义词所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

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

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存