oracle O7_DICTIONARY_ACCESSIBILITY参数

O7_DICTIONARY_ACCESSIBILITY参数控制对数据字典的访问.设置为true,如果用户被授予了如select any table等any table权限,用户即使不是dba或sysdba用户也可以访问数据字典.在9i及以上版本默认为false,8i及以前版本默认为true.如果设置为true就可能会带来安全上的一些问题.这也就为什么O7_DICTIONARY_ACCESSIBILITY 设置为false时,sys不能以normal方式登录的原因.实验如下: 


SQL> show parameter o7; 

NAME TYPE VALUE 
------------------------------------ ----------- ------------------------------ 
O7_DICTIONARY_ACCESSIBILITY boolean FALSE 
SQL> create user test identified by test ; 

用户已创建。 

SQL> grant resource,connect to test; 

授权成功。 

SQL> connect test/test; 
已连接。 

SQL> select count(*) from v$datafile; 
select count(*) from v$datafile 

第 1 行出现错误: 
ORA-00942: 表或视图不存在 


SQL> connect / as sysdba; 
已连接。 
SQL> grant select any table to test; 

授权成功。 

SQL> connect test/test; 
已连接。 



--即使授了select any table也无法查询V$视图 


SQL> select count(*) from v$datafile; 
select count(*) from v$datafile 

第 1 行出现错误: 
ORA-00942: 表或视图不存在 



SQL> connect / as sysdba; 
已连接。 

SQL> alter system set O7_DICTIONARY_ACCESSIBILITY=true scope=spfile; 

系统已更改。 

SQL> startup force 
ORACLE 例程已经启动。 

Total System Global Area 838860800 bytes 
Fixed Size 1251776 bytes 
Variable Size 260048448 bytes 
Database Buffers 570425344 bytes 
Redo Buffers 7135232 bytes 
数据库装载完毕。 
数据库已经打开。 



--设置为true就可以访问V$视图了 
SQL> connect test/test; 
已连接。 

SQL> select count(*) from v$datafile; 

COUNT(*) 
---------- 
20 

SQL> spool off; 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

赶路人儿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值