一尘不染

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

sql

只需使用类似的内容查询正在运行的作业

select * from dba_jobs_running;

在我的sqldevelopers SQL控制台中执行时,效果很好。

但是,在过程中具有完全相同的语句时,它不起作用。编译失败

PL/SQL: ORA-00942: table or view does not exist

有任何想法吗?是否有需要考虑的范围?

任何建议都将受到高度赞赏,在此先感谢:)


阅读 159

收藏
2021-05-05

共1个答案

一尘不染

您可能需要对拥有该过程的用户进行DBA_JOBS_RUNNING的直接授予。通过角色进行GRANT无效。…授予必须是明确的。

编辑:

从过程内执行SELECT与从过程外执行SELECT要求不同的权限(例如,在SQL-
Developer中)。拥有过程的用户必须已被明确授予表或视图的权限…如果不是从视图外部运行查询,则不是这种情况(例如,您可以通过角色来授予权限)

您需要以SYS身份连接并进入:

GRANT SELECT ON SYS.DBA_JOBS_RUNNING TO <user-that-owns-proc>;
2021-05-05