用synonym访问其它用户下的表

本文介绍了一种通过创建同义词来简化Oracle数据库中不同用户间表访问的方法。具体步骤包括创建只读用户、授予必要权限、创建同义词以及验证查询等,从而避免了每次查询时都需要指定完整表名的问题。

今天 有个开发人员提了个需求:比如有一个库上有一个用户A , A用户下建了2张表,    然后又建了个用户只读用户B  要求B用户能访问A用户下的表。通过授权是可以这样实现的,但是用户B每次访问用户A的话,得加A.table_name  说加  . 太麻烦了,问我有没有办法在不加A.的情况下就能访问A用户中 的表  。不加“user.”还真没有试过,经过请教别人,可以用同义词实现这样的方法。

假如所需要访问的表的用户为test用户,访问test用户的r_user表

SQL> show user;
USER 为 "SYS"



1、创建只读用户test_readonly
SQL> create user test_readonly identified by test_readonly default tablespace tbs_oracle_mrms temporary tablespace tbstemp quota unlimited on tbs_oracle_mrms;
用户已创建。

2、授予相关权限
SQL> grant connect to test_readonly;
授权成功。
SQL> grant create session to test_readonly;
授权成功。
SQL> grant select on test.r_user to test_readonly;
授权成功。
SQL> grant create synonym to usercenterReader;
权成功。


3、在只读用户下创建同义词

SQL> conn test_readonly/test_readonly;
SQL> create synonym r_user for test.r_user;
同义词已创建。

4、通过DBA权限回收synonym 权限
SQL> conn / as sysdba;
已连接。
SQL> revoke create synonym from test_readonly;
撤销成功。

5、在只读用户下查询test用户下的表
SQL> select * from r_user;

同义词视图:
select * from user_synonyms
  

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值