oracle允许所有用户访问一个用户的表的方法

来源:互联网 发布:mac的qq不能远程 编辑:程序博客网 时间:2024/05/23 18:57
SQL> create user zl identified by zl;
用户已创建。

SQL> alter user zl quota unlimited on system;
用户已更改。

SQL> grant create table to zl;
授权成功。

SQL> grant connect to zl;
授权成功。

SQL> conn zl/zl
已连接。
SQL> create table test(tid varchar(2));
表已创建。

SQL> insert into test values('11');
已创建 1 行。
SQL> select * from test;

TID                                                                             
----                                                                            
11                                                                              

------sys用户能查询到zl建立的表test
SQL> conn / as sysdba;
已连接。
SQL> select * from zl.test;

TID                                                                             
----                                                                            
11                                                                              

SQL> create user zl2 identified by zl2;
用户已创建。
SQL> grant connect to zl2;
授权成功。
SQL> conn zl2/zl2;
已连接。


------赋予权限之前访问不到zl用户的test表

SQL> select * from zl.test;
select * from zl.test
                 *
第 1 行出现错误: 
ORA-00942: 表或视图不存在 

SQL> conn / as sysdba;
已连接。
SQL> grant select on zl.test to public;
授权成功。

-----授权成功后能在其他用户zl2看到test表

SQL> conn zl2/zl2
已连接。
SQL> select * from zl.test;

TID                                                                             
----                                                                            

11                                                                              


SQL> spool off

---Sys登录撤销
SQL> revoke select on zl.test from public;
撤销成功。
原创粉丝点击