存储过程中有一条语句是EXECUTE IMMEDIATE 'CREATE TABLE TA (id integer)';当执行该存储过程时,可能会报“ORA-01031: 权限不足”的错误,但直接使用匿名块执行EXECUTE IMMEDIATE 'CREATE TABLE TA (id integer)'是成功的。
这是因为默认情况下,数据库对存储过程在编译阶段进行权限检测,数据库检测存储过程的所有者是否拥有直接赋予的权限,而不是通过一个角色等间接赋予的权限。但是在创建存储过程的时候使用了AUTHID CURRENT_USER这个选项,那么语句执行的权限将在执行过程中根据执行者的权限进行判断。
解决的方法有两个:一是直接授权用户DDL权限,二是使用AUTHID CURRENT_USER选项。
create or replace procedure p_test Authid Current_User as begin execute immediate 'create table creat_table(id number)'; end;
本文探讨了在Oracle数据库中,执行存储过程时遇到的ORA-01031权限不足错误。详细解释了此错误的原因在于数据库对存储过程的权限检查是在编译阶段,并且检查的是直接赋予的权限而非通过角色间接赋予的权限。文章提供了两种解决方案:直接授予用户DDL权限或者在创建存储过程时使用AUTHID CURRENT_USER选项。
644

被折叠的 条评论
为什么被折叠?



