Oracle 同义词概念:

  Oracle的同义词(synonyms)从字面上理解就是别名的意思,和视图的功能类似,就是一种映射关系。

  它可以节省大量的数据库空间,对不同用户的操作同一张表没有多少差别;它扩展了数据库的使用范围,能够在不同的数据库用户之间实现无缝交互;Oracle数据库中提供了同义词管理的功能。

  同义词是数据库对象的一个别名,经常用于简化对象访问和提高对象访问的安全性。

  在使用同义词时,Oracle数据库将它翻译成对应方案对象的名字。与视图类似,同义词并不占用实际存储空间,只有在数据字典中保存了同义词的定义。

  在Oracle数据库中的大部分数据库对象,如表、视图、物化视图、序列、函数、存储过程、包、同义词等等,数据库管理员都可以根据实际情况为他们定义同义词。

同义词分类:

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

  普通用户创建的同义词一般都是私有同义词,公有同义词一般由DBA创建,普通用户如果希望创建同义词,则需要CREATE PUBLIC SYNONYM这个系统权限。

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

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

同义词作用:

1):多用户协同开发中,可以屏蔽对象的名字及其持有者。

    如果没有同义词,当操作其他用户的表时,必须通过user名.object名的形式,采用了Oracle同义词之后就可以隐蔽掉user名,

    当然这里要注意的是:public同义词只是为数据库对象定义了一个公共的别名,其他用户能否通过这个别名访问这个数据库对象,还要看是否已经为这个用户授权。

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

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

4):Oracle同义词在数据库链接中的作用数据库链接是一个命名的对象,说明一个数据库到另一个数据库的路径,通过其可以实现不同数据库之间的通信。

Create database link 数据库链名 connect to user名 identified by 口令 using ‘Oracle连接串’; 访问对象要通过 object名@数据库链名。同义词在数据库链中的作用就是提供位置透明性。

创建同义词:

创建同义词的语法如下:

普通用法如下所示:

  1. CREATE [OR REPLACE] [PUBLIC] SYNONYM [ schema.] 同义词名称 FOR [ schema.] object [ @dblink ];
  2.  
  3. --专有(私有)同义词
  4.  
  5. CREATE SYNONYM SYSN_TEST FOR TEST;
  6.  
  7. --公共同义词
  8.  
  9. CREATE PUBLIC SYNONYM PUBLIC_TEST FOR TEST;

如果要创建一个远程的数据库上的某张表的同义词,需要先创建一个Database Link(数据库连接)来扩展访问,然后再使用如下语句创建数据库同义词:create synonym table_name for table_name@DB_Link;

公共同义词是和用户的schema无关的,但是公共的意思并不是所有的用户都可以访问它,必须被授权后才能进行;私有同义词是schema的对象。

同义词权限管理及使用:

与同义词相关的权限有CREATE SYNONYM、CREATE ANY SYNONYM、CREATE PUBLIC SYNONYM权限。

1):用户在自己的模式下创建私有同义词,这个用户必须拥有CREATE SYNONYM权限,否则不能创建私有同义词。

  1. ----------------------------创建私有的同义词---------------------------------
  2.  
  3. --使用System c##MLQ1用户授权创建 私有同义词的权限
  4. grant create synonym to c##MLQ1
  5.  
  6. --c##MLQ1 创建同义词(Student 是一张表)
  7. create synonym syn_MLQ1 for c##MLQ1.Student
  8.  
  9. --c##MLQ1 用户下本身调用同义词
  10. select * from syn_MLQ1
  11.  
  12. --使用c##MLQ 用户登录、查询(首先需要 c##MLQ1 用户给 c##MLQ 用户赋予查询权限)
  13. grant select on syn_MLQ1 to c##MLQ
  14.  
  15. --撤销查询权限
  16. revoke select on syn_MLQ1 from c##MLQ
  17.  
  18. --使用 c##MLQ 用户进行查询
  19. select * from c##MLQ1.syn_MLQ1

2):用户在自己的模式下创建共有同义词,这个用户必须拥有CREATE PUBLIC SYNONYM权限,否则不能创建公共同义词。

  1. ----------------------------创建公有的同义词---------------------------------
  2.  
  3. --使用System c##MLQ1用户授权创建 公共同义词的权限
  4. grant create public synonym to c##MLQ1
  5.  
  6. --c##MLQ1用户 创建公共同义词
  7. create public synonym syn_MLQ1_pub for c##MLQ1.userinfo
  8. ||
  9. create public synonym syn_MLQ1_pub for userinfo
  10.  
  11. --删除c##MLQ1 用户下的同义词
  12. drop synonym c##MLQ1.syn_MLQ1_pub
  13.  
  14. --c##MLQ1 用户下本身调用同义词
  15. select * from syn_MLQ1_pub
  16.  
  17. --使用c##MLQ 用户登录、查询(首先需要 c##MLQ1 用户给 所有用户赋予查询权限)
  18. grant select on syn_MLQ1_pub to public
  19. ||
  20. grant select on userinfo to public
  21.  
  22. --撤销查询权限
  23. revoke select on syn_MLQ1_pub from public
  24.  
  25. --使用 c##MLQ 用户进行查询
  26. select * from syn_MLQ1_pub

查看同义词:

  1. SQL> SELECT * FROM DBA_SYNONYMS WHERE SYNONYM_NAME IN ( 'SYSN_TEST','PUBLIC_TEST');
  2.  
  3. OWNER SYNONYM_NAME TABLE_OWNER TABLE_NAME DB_LINK
  4.  
  5. ------------------------------ ------------------------------
  6. PUBLIC PUBLIC_TEST ETL TEST
  7.  
  8. ETL SYSN_TEST ETL TEST
  9.  
  10. SQL> SELECT * FROM USER_SYNONYMS

使用同义词:

  1. SELECT * FROM SYSN_TEST;

使用同义词可以保证当数据库的位置或对象名称发生改变时,应用程序的代码保持稳定不变,仅需要改变同义词;

当使用一个没有指定schema的同义词是,首先在用户自己的schema中寻找,然后再公共同义词中寻找

删除同义词:

  1. DROP [ PUBLIC ] SYNONYM [ schema. ] 同义词名称 [ FORCE ];
  2.  
  3. DROP SYNONYM SYSN_TEST;
  4.  
  5. DROP PUBLIC SYNONYM PUBLIC_TEST;--当同义词的原对象被删除是,同义词并不会被删除

编译同义词:

ALTER  SYNONYM T COMPILE; --当同义词的原对象被重新建立时,同义词需要重新编译

对原对象进行DDL操作后,同义词的状态会变成INVALID;当再次引用这个同义词时,同义词会自动编译,状态会变成VALID,无需人工干预,当然前提是不改变原对象的名称

  1. SQL> SELECT * FROM T;
  2.  
  3. ID NAME
  4. ----------- -------------
  5.  
  6. SQL> SELECT * FROM TEST;
  7.  
  8. ID NAME
  9. ----------- --------------
  10.  
  11. SQL> ALTER TABLE TEST ADD SEX NUMBER(1);
  12.  
  13. Table altered
  14.  
  15. SQL> SELECT OBJECT_NAME, STATUS FROM ALL_OBJECTS WHERE OBJECT_NAME='T';
  16.  
  17. OBJECT_NAME STATUS
  18. ------------------------------ -------
  19. T INVALID

问题锦集:

1:公用同义词与私有同义词能否同名呢?如果可以,访问同义词时,是共有同义词还是私有同义词优先?

  可以,如果存在公用同义词和私有同义词同名的情况,在访问同义词是,访问的是私有同义词的指向的对象。

2:为啥OE用户创建的公用同义词,HR用户不能访问呢?

  因为HR没有访问OE模式下对象的权限,如果OE模式给HR用户赋予了SELECT对象等权限,那么HR用户即可访问。

.........后续有待更新

Face your past without regret. Handle your present with confidence.Prepare for future without fear. keep the faith and drop the fear.

面对过去无怨无悔,把握现在充满信心,备战未来无所畏惧。保持信念,克服恐惧!一点一滴的积累,一点一滴的沉淀,学技术需要不断的积淀!

分享知识-快乐自己:Oracle中定义及使用同义词的更多相关文章

  1. 转://Oracle中定义者权限和调用者权限案例分析

    定义者权限:定义者权限指使用它所有者的权限,而不是当前用户来执行过程.因此,你可以限制用户执行的数据库操作,允许他们仅通过运行定义者权限的过程和函数访问数据.创建过程.函数和程序包的默认权限是定义者权 ...

  2. Oracle中定义package以及存储过程的使用

    使用scott账户下的dept表: select * from dept order by deptno; 10 ACCOUNTING NEW YORK 20 RESEARCH DALLAS 30 S ...

  3. .Net处理Oracle中Clob类型字段总结

    最近在做项目中用到Clob这个字段,Clob是存储无限长字符的Oracle字段,用的时候网上找资料找了好久,内容不是很多,大部分都不能用,当然也有可以用的,测试了不同版本,整理了一下,给大家在做项目的 ...

  4. 关于oracle中数据类型的选择

    由于是初学,犯了如下错误: 生成表的主键id时,用当前时间的毫秒值.而在oracle中定义主键id时,用的数据类型是char(32).在mybatis中通过id取数据怎么也取不出来.想了好几天,本来以 ...

  5. oracle中clob字段的使用

    oracle中定义了一个字段是clob的,由于用的是ssh的框架,结果在面向对象存取的时候出现clob类型字段和String类型字段的转换问题.开始查阅了clob字段和String字段的相互转换的方法 ...

  6. oracle中length、lengthb、substr、substrb用法小结

    我记得我曾经在开发form的时候犯过这样一个错误,对于form中的某个字段,对应于数据库中某张表的字段,假设在数据库中这个字段一般也就用到20个汉字的长度,后来我在开发form的时候,设置item类型 ...

  7. oracle中的创建过程,函数,包

    一.创建存储过程 存储过程是在oracle中存取完成特定业务逻辑的代码块.存储过程是命名块,匿名块不存在数据库中,命名块会存储到数据库中,匿名块每次运行都需要提前编译,命名块一次存储,只会编译一次.命 ...

  8. [oracle] ORA-08002:序列XXXXXXX.CURRVAL尚未在此进程中定义

    出现 ORA-08002: 序列XXXXXXX.CURRVAL 尚未在此进程中定义. 导致原因:因为是首次查询序列的当前值,内存中之前并没有缓存序列的任何值,所以需要先查询 一下序列的下一个值(此时, ...

  9. Oracle中如何导出存储过程、函数、包和触发器的定义语句?如何导出表的结构?如何导出索引的创建语句?

    Oracle中如何导出存储过程.函数.包和触发器的定义语句?如何导出表的结构?如何导出索引的创建语句? QQ群里有人问:如何导出一个用户下的存储过程?   麦苗答:方法有多种,可以使用DBMS_MET ...

随机推荐

  1. hdu1394 Minimum Inversion Number(最小逆序数)

    Minimum Inversion Number Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/O ...

  2. HDU 1875 畅通project再续 (最小生成树 水)

    Problem Description 相信大家都听说一个"百岛湖"的地方吧,百岛湖的居民生活在不同的小岛中,当他们想去其它的小岛时都要通过划小船来实现. 如今政府决定大力发展百岛 ...

  3. FileUpload控件预览图片

    HTML代码: <tr> <td class="auto-style1">上传图片:</td> <td> <asp:FileU ...

  4. ThreadLocal,LinkedBlockingQueue,线程池 获取数据库连接2改进

    package com.ctl.util; import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQL ...

  5. 原创 | 我被面试官给虐懵了,竟然是因为我不懂Spring中的@Configuration

    GitHub 3.7k Star 的Java工程师成神之路 ,不来了解一下吗? GitHub 3.7k Star 的Java工程师成神之路 ,真的不来了解一下吗? GitHub 3.7k Star 的 ...

  6. python之脚本参数optparse

    import optparse usage = "myprog[ -f <filename>][-s <xyz>] arg1[,arg2..]" opter ...

  7. 看完这篇还不会自定义 View ,我跪搓衣板

    自定义 View 在实际使用的过程中,我们经常会接到这样一些需求,比如环形计步器,柱状图表,圆形头像等等,这时我们通常的思路是去Google 一下,看看 github 上是否有我们需要的这些控件,但是 ...

  8. Tsung 初步介绍安装

    tsung是erlang的一个开源的一个压力测试工具,可以测试包括HTTP, WebDAV, Mysql, PostgreSQL, LDAP, and XMPP/Jabber等服务器.针对 HTTP ...

  9. [Linux] 网络

    如何在网络中标识一台计算机 IP 多个程序如何不冲突 通信端口 不同的计算机如何通信 协议 IP A类:0+7位网络号+24位主机号,可用网络2^7-2个,每个网络可容纳2^24-2个主机 B类:10 ...

  10. attr/attrs模块

    attr简介 开源库,提供了为函数或类提供更直接的创建属性的方法. Github or PyPi 用法 from attr import attrs, attrib @attrs class Foo: ...