一. 问题:
如何实现在Oracle数据库中访问其他用户的表时不需加表所属的用户名
二. 举例:
Oracle里面的用户A,要访问用户B的表需要带用户B的前缀,如访问用户B的 TEST表,需要这样访问 select * from B.TEST;现在就是问如何才能无需添加用户名的前缀。
三. 原因:
- 方便访问常用表
- 隐藏表的用户
四. 解决方案:
1. 创建同义词
语法:
CREATE [PUBLIC] SYNONYM synonym_name FOR [schema.] object[@db_link];```` 根据举例进行延伸演示: (1)登录sysdba为用户B授予创建同义词的操作权限: sqlplus /nolog conn /as sysdba; grant create synonym to B; (2)登录B用户为A授予访问特定表TEST的权限: //注意:这是A用户能够使用同义词访问B的TEST表的前提 grant select on TEST to A; //撤销的方式: revoke select on TEST from A; (3)创建同义词 create synonym SY_TEST for B.TEST; (4)登录用户A进行测试. #####2.创建视图 create view VW_TEST select * from B.TEST; #####3.修改current_schema参数 用于切换当前会话的架构(schema)。在进行对象名解析时,如果对象名前没有限定架构名,oracle 会自动在此架构下查询匹配的对象。 例如,当 scott 用户执行```` select * from emps; ````语句时,oracle 默认会查询 scott 架构下的 emps 表;但是,如果```` alter session set current_schema=xx; ````更改了会话的当前架构,执行此语句时 oracle 会查询 xx 架构下的 emps 表。
登录用户A时,临时修改current_schema参数: SQL> alter session set current_schema=B; Session altered. SQL> show user; USER is "A" SQL> select SYS_CONTEXT('USERENV','CURRENT_SCHEMA') CURRENT_SCHEMA from dual; CURRENT_SCHEMA -------------------------------------------------------------------------------- B SQL> SQL> spool off;
这种方式只是适用于当前一次会话,一旦会话关闭,下次就不行了.所以此种方式一次可行,但是通用不行.