回答

收藏

dba_jobs_running:尝试从过程中访问时,表或视图不存在

技术问答 技术问答 75 人阅读 | 0 人回复 | 2023-09-13

只需使用类似的内容查询正在运行的作业  N6 F" [! C5 v
select * from dba_jobs_running;, G+ R: k& C( ]( w7 P: h% k4 M, m
在我的sqldevelopers SQL控制台中执行时,效果很好。$ Z: ]' ~' J& d
但是,在过程中具有完全相同的语句时,它不起作用。编译失败4 I' W& D0 B5 [7 h' i. e) B
PL/SQL: ORA-00942: table or view does not exist7 V3 O2 b2 W, _; [, ~5 G1 K0 K5 `% U
有任何想法吗?是否有需要考虑的范围?9 v! Q- N; g, `7 G* ?
任何建议都将受到高度赞赏,在此先感谢( A. N% K# F" q: b! y* [/ e. M
               
2 J$ D" `; `, c  H' N/ w% s) g解决方案:
6 b; ?4 _% b. k' A/ u. K: G* b8 J               
% R# K7 \5 L- R' }2 j0 n
: p* j& N& B2 n' ~8 L5 D5 ^* O9 O
' S5 W/ A" a% [) I* ~                您可能需要对拥有该过程的用户进行DBA_JOBS_RUNNING的直接授予。通过角色进行GRANT无效。…授予必须是明确的。
) t- ~' U7 Z8 }5 a编辑:; F0 u, u$ ]* {1 ?
从过程内执行SELECT与从过程外执行SELECT要求不同的权限(例如,在SQL-# Q2 Y. h: n5 w. `
Developer中)。拥有过程的用户必须已被明确授予表或视图的权限…如果不是从视图外部运行查询,则不是这种情况(例如,您可以通过角色来授予权限)
- r$ S- @$ S% i8 }9 _, T- A您需要以SYS身份连接并进入:2 q8 l$ r8 J2 W4 J  V4 j0 I6 B
GRANT SELECT ON SYS.DBA_JOBS_RUNNING TO <u>;
分享到:
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则