zoukankan      html  css  js  c++  java
  • oracle之同义词

    同义词

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

    14.1 私有同义词;

    一般是普通用户自己建立的同义词,创建者需要create synonym 权限。

    sys:
    SQL> grant create synonym to scott;        //sys授权给scott建立私有同义词权限
    scott:
    SQL> create synonym abc for emp;        //scott建立了一个私有同义词
    SQL> select * from abc            //scott可以使用这个私有同义词了

    如何让tim用户也使用这个私有同义词
    SQL> grant select on scott.emp to tim;        //把访问基表的对象权限给tim
    tim:
    SQL> select * from scott.abc;            //tim使用同义词时加模式名前缀,OK。

    14.2 公有同义词;

    一般是由DBA创建,使所有用户都可使用, 创建者需要create public synonym权限。

    create public synonym syn2 for ...

    用户要访问public synonym, 需要有访问基表的权限。

    select * from tab; (tab是什么?); 用下面的查看语句:

    select * from all_objects where object_name='TAB';
    select * from all_synonyms where synonym_name='TAB';

    查看同义词的视图:dba_synonyms
    删除私有同义词:drop synonym 同义词名
    删除公有同义词:drop public synonym 同义词名

    SQL>select * from dba_synonyms where synonym_name='SYN1';

    14.3 关于同义词的几个要点:

    1)私有同义词是模式对象,一般在自己的模式中使用,如其他模式使用则必须用模式名前缀限定。

    2)公有同义词不是模式对象,不能用模式名做前缀。(考点)

    3)私有和公有同义词同名时,如果指向不同的对象,私有同义词优先。

    4)引用的同义词的对象(表或视图)被删除了,同义词仍然存在,这同视图类似,重新创建该对象名,下次访问同义词时自动编译。(考点)

  • 相关阅读:
    linux下守护进程的创建
    【转】ps命令详解
    【转】适配器模式
    【转】设计模式六大原则(6):开闭原则
    【转】设计模式六大原则(5):迪米特法则
    【转】设计模式六大原则(4):接口隔离原则
    【转】设计模式六大原则(3):依赖倒置原则
    【转】设计模式六大原则(2):里氏替换原则
    网站会不会因为同IP网站被K而受到惩罚
    网页加载速度是否影响网站排名
  • 原文地址:https://www.cnblogs.com/jinxf/p/9166636.html
Copyright © 2011-2022 走看看