在存储过程中创建动态表而在 PL/SQL 块表中创建时权限不足[重复]
Posted
技术标签:
【中文标题】在存储过程中创建动态表而在 PL/SQL 块表中创建时权限不足[重复]【英文标题】:Insufficient privilege when create dynamic table in stored procedure while in PL/SQL block table has been created [duplicate] 【发布时间】:2019-07-22 11:53:59 【问题描述】:当我在存储过程中执行包含EXECUTE IMMEDIATE
和create table
语句的存储过程时,然后在执行此存储过程时出错。
这是存储过程-
create or replace sp_exec
as
.......
v_mth date;
.......
begin
select to_char(add_months(current_DATE, -1), 'MON_YY') INTO v_mth FROM dual;
execute immediate 'create table tbl_mon_' ||v_mth|| ' as select ............... from ..... ';
end;
当我尝试执行此存储过程时,在使用此代码执行存储过程的第二行最后一行出现错误“Insufficient Privilege”。
begin
sp_exec;
end;
然后得到下面提到的错误:-
ORA-01031: Insufficient privilege
ORA-06512: at sp_exec line 11 --here line 11 mention for Execute immediate
ORA-06512: at line 2 -- here mention for sp_exec in the PLSQL block
我在用户模式本身中工作,所以我拥有所有类型的权限,甚至CREATE TABLE
语句也是如此。当我在存储过程(PL/SQL 块)之外运行时,动态表已创建。
【问题讨论】:
动态创建月表似乎是一个很糟糕的设计。 例如物化视图或分区 【参考方案1】:显然,您通过角色获得了create table
权限。它不适用于命名的 PL/SQL 过程,这意味着您必须将其直接授予用户。
【讨论】:
您是否有权从作为您动态创建的表的源的表中进行选择?您发布的代码表明您正在选择from v_mth
,其中˙v_mth
是日期;您不能从名称为 01-JUN-19 的表中进行选择,可以吗?
好的,但是您的代码显示:as select ............... from '|| v_mth ||' ..... '
。 v_mth
等于 01-JUN-19(或数据库中默认返回的任何格式 TO_DATE)。这是一个无效的表名。当然,除非您过度简化了您发布的代码。尝试创建一个我们能够重现的简单示例。以上是关于在存储过程中创建动态表而在 PL/SQL 块表中创建时权限不足[重复]的主要内容,如果未能解决你的问题,请参考以下文章
为啥我们要编写 create/replace 来在 PL/SQL 中创建过程