只需使用类似的内容查询正在运行的作业
select * from dba_jobs_running;
在我的sqldevelopers SQL控制台中执行时,效果很好。
但是,在过程中具有完全相同的语句时,它不起作用。编译失败
PL/SQL: ORA-00942: table or view does not exist
有任何想法吗?是否有需要考虑的范围?
任何建议都将受到高度赞赏,在此先感谢:)
您可能需要对拥有该过程的用户进行DBA_JOBS_RUNNING的直接授予。通过角色进行GRANT无效。…授予必须是明确的。
编辑:
从过程内执行SELECT与从过程外执行SELECT要求不同的权限(例如,在SQL- Developer中)。拥有过程的用户必须已被明确授予表或视图的权限…如果不是从视图外部运行查询,则不是这种情况(例如,您可以通过角色来授予权限)
您需要以SYS身份连接并进入:
GRANT SELECT ON SYS.DBA_JOBS_RUNNING TO <user-that-owns-proc>;