日期:2014-05-17  浏览次数:21161 次

创建表 ora-01031 权限不足,不知道怎么搞,
我的程序如下:

create   or   replace   procedure   aaa
is
              ssql   varchar2(1000);
begin
              ssql:= 'create   table   asdf   as   select   *   from   gyf_c ';
              execute   immediate   ssql;
end   aaa;

哪位高手帮忙解决下??

------解决方案--------------------
SQL> create procedure cccccc
2 as
3 s_q varchar2(100);
4 begin
5 s_q := 'create table cc(id number) ';
6 execute immediate s_q;
7 end;
8 /

过程已创建。

SQL> exec cccccc;
BEGIN cccccc; END;

*
ERROR 位于第 1 行:
ORA-01031: 权限不足
ORA-06512: 在 "SYSTEM.CCCCCC ", line 6
ORA-06512: 在line 1


SQL> conn /as sysdba
已连接。
SQL> grant create table to system;

授权成功。

SQL> conn system/love2008
已连接。
SQL> exec cccccc;

PL/SQL 过程已成功完成。

------解决方案--------------------
system应该有create table 的权限阿
sys@HASL> alter user system identified by manager account unlock;

用户已更改。

sys@HASL> conn system/manager@haslxdb
已连接。
sys@HASL> create or replace procedure aaa
2 is
3 ssql varchar2(1000);
4 begin
5 ssql:= 'create table asdf(id char(10)) ';
6 execute immediate ssql;
7 end aaa;
8 /

过程已创建。

sys@HASL> exec aaa;

PL/SQL 过程已成功完成。

sys@HASL> show user
USER 为 "SYSTEM "
sys@HASL> select *from asdf;

未选定行