ORA-06512 問題解決

pxbibm發表於2017-09-26
在執行儲存過程時,有動態執行SQL時,有時報錯ORA-06512。

SQL> select * from dba_role_privs where grantee='dev';
 
  GRANTEE GRANTED_ROLE ADMIN_OPTION DEFAULT_ROLE
  ------------ ------------ ------------ ------------
  DEV CONNECT NO YES
  DEV RESOURCE NO YES
  
  --再建立一個測試儲存過程:
  create or replace procedure p_create_table  
  is
  begin
  Execute Immediate 'create table test(id int)';
  end p_create_table;
 
  --然後測試
  SQL> exec p_create_table;
 
  begin p_create_table; end;
 
  ORA-01031: 許可權不足
  ORA-06512: 在"DEV.P_CREATE_TABLE", line 3
  ORA-06512: 在line 1
 
  --可以看到,即使擁有CONNECT,RESOURCE  role,也不能建立表。role在儲存過程中不可用。
  --遇到這種情況,我們一般需要顯式進行系統許可權,如grant create table to DEV;
  --但這種方法太麻煩,有時候可能需要進行非常多的授權才能執行儲存過程
  --實際上,oracle給我們提供了在儲存過程中使用role許可權的方法:
  --修改儲存過程,加入Authid Current_User時儲存過程可以使用role許可權。
  create or replace procedure p_create_table  
  Authid Current_User is
  begin
  Execute Immediate 'create table test(id int)';
  end p_create_table;
 
  --再嘗試執行:
  SQL> exec p_create_table;
 
  PL/SQL procedure successfully completed
 
  --已經可以執行了。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/12798004/viewspace-2145425/,如需轉載,請註明出處,否則將追究法律責任。

相關文章