用synonym访问其它用户下的表
来源:互联网 发布:网络攻击的种类 编辑:程序博客网 时间:2024/05/21 17:31
今天 有个开发人员提了个需求:比如有一个库上有一个用户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
- 用synonym访问其它用户下的表
- 访问其它用户下的对象
- oracle 存储过程 访问其它用户的表
- Oracel Synonym 跨实例访问表
- oracle存储过程访问其它用户表权限不足
- 存储过程在调用其它用户下的表时,显示不存在该表
- windows xp下如何设置其它用户的权限
- linux下注销其它用户或者tty的命令
- win7下 iis7 配置可以让局域网内其它用户访问
- 如果用户没有登陆直接通过url访问其它页面的解决办法
- 访问应用程序的其它类
- 访问不了msdn的网站(打开其它的网址很正常,同一局域网下其它的电脑就可以)
- LINUX下的用户访问授权
- Orcle的package中访问其它Schema的表
- 悬而未决:不重新启动WINDOWS如何以其它用户身份访问已经以一用户账号打开的共享文件夹
- db2 使用nickname 访问其它库的表
- db2 使用nickname 访问其它库的表
- synonym的限制
- finally语句详解
- 改变你思维模式的书单
- MySQL权限管理
- Android Fragment 真正的完全解析(下)
- 项目无错误Tomcat启动时间过长
- 用synonym访问其它用户下的表
- JForum论坛搭建
- freemarker变量自加
- KDtree简单版本
- 【单调队列】 贪心 序列
- 【接口开发】浅谈 SOAP Webserver 与 Restful Webserver 区别
- Android错误android.content.res.Resources$NotFoundException:
- 完成端口示例
- C++基础3:algorithm库的基础用法