ORA-00942: table or view does not exist_MySQL, Oracle及数据库讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  MySQL, Oracle及数据库讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 2622 | 回复: 0   主题: ORA-00942: table or view does not exist        下一篇 
shary
注册用户
等级:新兵
经验:54
发帖:66
精华:0
注册:2011-8-31
状态:离线
发送短消息息给shary 加好友    发送短消息息给shary 发消息
发表于: IP:您无权察看 2015-7-3 15:49:06 | [全部帖] [楼主帖] 楼主

在过程,包,函数,触发器中调用Oracle相关动态性能视图时,需要授予适当的权限,否则会收到表和视图不存在的错误提示。即使可以单独查询这些视图。因为动态性能视图依赖于底层表,无法直接对其授予权限。下面就是这个现象相关的例子。

1、过程调用动态视图无法成功编译的示例

SQL> select * from v$version where rownum<2;
BANNER
----------------------------------------------------------------
Oracle Database 10g Release 10.2.0.5.0 - 64bit Production
SQL> show user;
USERis"GX_ADM"
SQL> CREATEORREPLACEPROCEDURE tst
2  AS
3      v_usr   VARCHAR2(30);
4  BEGIN
5  SELECT username INTO v_usr FROM v$process WHERE ROWNUM < 2;
6  DBMS_OUTPUT.put_line ('Username is '   v_usr);
7  END;
8  /
Warning: Procedure created with compilation errors.
SQL> show errors;
Errors forPROCEDURE TST:
LINE/COL ERROR
-------- -----------------------------------------------------------------
5/1      PL/SQL: SQL Statement ignored
5/33     PL/SQL: ORA-00942: tableorview does not exist


2、分析与解决

--根据上面提示的错误信息,咋一看就是表和视图不存在


--而实际上动态性能视图是一个同义词,并非真正的视图,下面尝试使用sys帐户对其赋予权限到所需用户


--收到了ORA-02030错误信息,也就是说只能对固定的表和视图进行权限赋予


SQL> conn / as sysdba
Connected.
SQL> grantselecton v$process to gx_adm;
grantselecton v$process to gx_adm
*
ERROR at line 1:
ORA-02030: can onlyselectfrom fixed tables/views
SQL> conn gx_adm/xxx  -->使用gx_adm用户连接数据库


Error accessing PRODUCT_USER_PROFILE
Warning:  Product user profile information not loaded!
You may need to run PUPBLD.SQL as SYSTEM
Connected.
--用户本身是可以访问该动态性能视图的


SQL> select username FROM v$process WHERE ROWNUM < 2 and username isnotnull;
USERNAME
---------------
oracle
SQL> conn / as sysdba
Connected.
--Author : Leshami
--Blog   : http://blog.csdn.net/leshami
--基于真实的视图授予权限


SQL> grantselecton v_$process to gx_adm;
Grant succeeded.
--下面再次编译正常


gx_adm@CNMMBO> alterprocedure tst compile;
Procedure altered.
--我们也可以通过执行计划来查看底层访问对象为X$KSUPR,这也就是为什么前面授权失败的原因


SQL> set autot trace exp;
SQL> select username FROM v$process WHERE ROWNUM < 2 and username isnotnull;
Execution Plan
----------------------------------------------------------
------------------------------------------------------------------
Id    Operation           Name      Rows    Bytes   Cost (%CPU)
------------------------------------------------------------------
0   SELECT STATEMENT                  1      35       0   (0)
1    COUNT STOPKEY
2     FIXED TABLEFULL  X$KSUPR       1      35       0   (0)
------------------------------------------------------------------


--转自 北京联动北方科技有限公司




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论