今天从其他系统拷贝了一个存储过程到一个新的用户(user1)下面,但在编译的时候发现定义的一个游标访问dba_tables的地方报错:“表不存在”。觉得很奇怪,因为这个表是存在的,在plsql中新建一个窗口:然后输入“select * from dba_tables”,执行没有任何问题!再看一下当前用户的角色,里面包含了DBA权限,那为什么会报这个错呢?后来尝试用sys用户执行了以下语句:“grant select on dba_tables to user1”,执行完毕后,之前的存储过程编译通过了,看来在存储过程中执行某个语句和单独执行还是有点差异的,其中的具体细节还未具体研究,待今后研究。。。
oracle存储过程权限问题
最新推荐文章于 2023-08-06 09:17:09 发布