300字范文,内容丰富有趣,生活中的好帮手!
300字范文 > 如何解决关于Oracle存储过程执行权限问题 – 数据库 – 前端

如何解决关于Oracle存储过程执行权限问题 – 数据库 – 前端

时间:2018-07-02 19:59:50

相关推荐

如何解决关于Oracle存储过程执行权限问题 – 数据库 – 前端

在数据库系统中存储过程是必不可少的利器,存储过程是预先编译好的为实现一个复杂功能的一段Sql语句集合。它的优点偶就不多说了,说一下偶碰到的问题吧。偶在项目开发的过程中需要用存储过程来实现一个功能,其中涉及到判断一张表是否已经建立,没有建立就由存储过程来建立这张表。

CREATE OR REPLACE PROCEDURE TestProc

IS

flag number;

BEGIN

select count(*) into flag from all_tables where table_name=’TEMP3′;

if (flag=0) then

execute immediate ‘create global temporary table TEMP3 on commit preserve rows as select * from BUSI_ECONTRACT’;

else

execute immediate ‘insert into TEMP3 select * from BUSI_ECONTRACT’;

end if;

END ;

写这段存储过程比较简单,在测试执行的过程中,系统出现如下提示:

ora -01031 :权限不足

从错误提示大家定位到错误,发现存储过程在执行 Create table语句时,权限不足。偶尝试着把存储过程改成匿名存储过程在PL/SQL中执行,语句既然通过了。这说明这段语句没有问题,问题出现在执行存储过程中。偶使用的是DBA帐号登录系统,按理应该不存在权限不足的问题呀。问题出现再哪里呢?通过上网查阅资料,发现Oracle对于执行存储过程有和Sql-Server不一样的规定,这个规定造成了执行建表语句权限不足。

Oracle规定,在默认的情况下,在调用存储过程用户的角色不起作用,即在执行存储过程时只有Public权限。所以在调用Create table时,会有权限不足的提示。

存储过程分为两种,即DR(Definer’s Rights ) Procedure和IR(Invoker’s Rights ) Procedure。为什么会有两种存储过程呢?其实考虑完下面的问题就清楚了。比如说用户hrch创建了删除表tar_table的存储过程drop_table(),当用户hrch调用时,即删除用户hrch下

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。