ORA-01031:权限不足

oracle执行存储过程出错

create or replace procedure test1as sql1 varchar2(4000);no_result exception;begin     sql1:='update oa.test set id =1';     execute immediate sql1;     commit;exception         when no_result then              dbms_output.put_line('error');end;
这个存储过程用来更新用来用户一个表,然后OANEWPLATDJ登录执行时报

ORA-01031:权限不足
ORA-06512:在"OANEWPLATDJ.TEST1",line8
ORA-06512:在line 3

百度之,

有两种方法可以解决:一、创建存储过程时在存储过程名后增加  Authid Current_User 如
create or replace procedure tt_senquence  Authid Current_User is ...
 
二、显示授予该用户相关系统权限 如:
grant update any table to  &user_name;
grant insesrt any table to  &user_name;

两种方法各有利弊;
第一种方法不用显示授于各种系统权限,比较方便。
但如果在job中调用该存储过程则还会报ORA-01031: 权限不足的错误。

第二种方法:虽然麻烦,但可以解决job中调用存储过程的问题。

posted on 2019-12-26 17:58  菜鸟瞎扑腾  阅读(3258)  评论(0编辑  收藏  举报

导航