cainiaoputeng

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中调用存储过程的问题。

分类:

技术点:

相关文章:

  • 2021-12-09
  • 2021-10-16
  • 2021-10-14
  • 2021-12-18
  • 2021-10-14
  • 2021-09-27
猜你喜欢
  • 2021-11-07
  • 2021-07-28
  • 2021-11-07
  • 2021-10-14
  • 2021-11-21
  • 2021-10-14
  • 2021-10-18
相关资源
相似解决方案