oracle同义词SYNONYM

2014-11-14

SYNONYM同义词的主要作用就是给一个数据库对象(表、视图等)一个别名,同义词有两种类型:私有(private)和公共(public)。多用户协同开发中,可以屏蔽对象的名字及其持有者。

CREATE [PUBLIC]SYNONYM synonym For schema.object
  隐藏对象的名称和所有者:
  select count(*) from hr.employees;

grant create synonym to hr;
grant create synonym to scott;

conn /as sysdba
  create synonym emp for hr.employees; --默认属于donny用户,是donny的私有对象private
  select count(*) from emp;
  为分布式数据库的远程对象提供了位置透明性:
  
访问其他数据库时,要首先建立数据库连结:
  CREATE DATABASE LINK test_link CONNECT TO username IDENTIFIED BY password USING 'DB01';
  Select count(*) from hr.employees@test_link;
  create synonym link_emp for hr.employees@test_link;
  select count(*) from link_emp;
  
提供对象的公共访问:
  create public synonym pub_emp for hr.employees;
  pub_emp属于public用户,数据库所有用户都可以访问。
  
同义词类型
  –私有 emp 实际上donny.emp
  –公用 pub_emp 所有用户都可以直接访问
  当公有对象和私有对象同名时(因为数据不同的用户,所以可以),以私有对象优先。(类似于局部变量)
  desc dba_synonyms/ user_synonyms/ all_synonyms 数据字典,复数
  tab公有同义词
  建立私有的tab表,查看效果。
  删除同义词:
  drop synonym donny.emp;
  drop public synonym pub_emp;

分类:数据库 | 标签: |

相关日志

评论被关闭!