Oracle动态执行表不可访问,本会话的自动统计会被禁止

1 篇文章 0 订阅
1 篇文章 0 订阅

--问题描述

动态执行表不可访问是什么意思,本会话的自动统计会被禁用,或在v$session,v$sesstat和v$statname表里获取权限

-- 解决方法

对这三张表进行授权(推荐方法)

工具: PLSQL Developer

以超级管理员身份sys, 连接为SYSDBA进行登录, 如下:

 连接上后, 依次打开菜单 文件——>新建——>SQL窗口, 执行以下的sql语句, 比如对普通用户scott进行授权, 如下:

grant select on v$statname to scott;
grant select on v$sesstat to scott;
grant select on v$session to scott;
grant select on v$mystat to scott;
---scott是你要授权的用户

如果取消权限, 则如下:

revoke select on v$statname from scott;
revoke select on v$sesstat from scott;
revoke select on v$session from scott;
revoke select on v$mystat from scott;

--可能出现的问题

1、ORA-02030: 只能从固定的表/视图查询

 

这是因为v$mystat不是一个视图,其实它是一个同义词。这些视图查询是需要在sys下显示授权后才能在存储过程中使用。但是,如果我们使用grant on v$view to username,则会收到ORA-02030错误。

因此,需要将同义词对应的视图(v_$)进行授权,如下:

grant select on v_$statname to scott;
grant select on v_$sesstat to scott;
grant select on v_$session to scott;
grant select on v_$mystat to scott;

以及其他常用的查询表:

1、会话信息

SQL> grant select on v_$session to scott;

2、SQL信息

SQL> grant select on v_$sql to scott;

3、SQL详情

SQL> grant select on v_$sqltext to scott;

4、锁表对象

SQL> grant select on v_$locked_object to scott;

--若其他问题欢迎留言讨论

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值