只需使用类似的内容查询正在运行的作业
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中)。拥有过程的用户必须已被明确授予表或 View 的权限...如果不是从 View 外部运行查询,则不是这种情况(例如,您可以通过角色来授予权限)
您需要以SYS身份连接并进入:
GRANT SELECT ON SYS.DBA_JOBS_RUNNING TO <user-that-owns-proc>;
关于sql - dba_jobs_running : table or view does not exist when trying to access from procedure,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/968857/