写了一个存储过程,在里面用create table创建表,结果发现:
ora-01031 的错误.
手工给当前用户create table 的权限,问题解决.
后来在网上发现,主要是role的角色没有起使用,还有以下的解决办法:
可以看到,即使拥有DBA role,也不能创建表。role在存储过程中不可用。
--实际上,oracle给我们提供了在存储过程中使用role权限的方法:
--修改存储过程,加入Authid Current_User时存储过程可以使用role权限。
create or replace procedure p_create_table
Authid Current_User is
begin
Execute Immediate 'create table create_table(id int)';
end p_create_table;
--再尝试执行:
SQL> exec p_create_table;
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/197458/viewspace-1026446/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/197458/viewspace-1026446/