如何在儲存過程中擁有role的許可權
我們知道,使用者擁有的role許可權在儲存過程是不可用的。如:
SQL> select * from dba_role_privs where grantee='SUK';
GRANTEE GRANTED_ROLE ADMIN_OPTION DEFAULT_ROLE
------------ ------------ ------------ ------------
SUK DBA NO YES
SUK CONNECT NO YES
SUK RESOURCE NO YES
--使用者SUK擁有DBA這個role
--再建立一個測試儲存過程:
create or replace procedure p_create_table
is
begin
Execute Immediate 'create table create_table(id int)';
end p_create_table;
--然後測試
SQL> exec p_create_table;
begin p_create_table; end;
ORA-01031: 許可權不足
ORA-06512: 在"SUK.P_CREATE_TABLE", line 3
ORA-06512: 在line 1
--可以看到,即使擁有DBA role,也不能建立表。role在儲存過程中不可用。
--遇到這種情況,我們一般需要顯式進行系統許可權,如grant create table to suk;
--但這種方法太麻煩,有時候可能需要進行非常多的授權才能執行儲存過程
--實際上,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;
PL/SQL procedure successfully completed
--已經可以執行了。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/231499/viewspace-63761/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 讓使用者擁有儲存過程的除錯許可權儲存過程除錯
- 儲存過程與許可權儲存過程
- ORACLE中儲存過程的許可權問題Oracle儲存過程
- mysql儲存過程的許可權 definerMySql儲存過程
- 儲存過程與許可權(二)儲存過程
- 定義者許可權儲存過程role無效,必須要有顯式授權儲存過程
- MySQL儲存過程的許可權問題MySql儲存過程
- 資料庫許可權-儲存過程資料庫儲存過程
- oracle儲存過程許可權繼承小結Oracle儲存過程繼承
- 儲存過程許可權__Authid Current_User儲存過程
- 檢視、儲存過程以及許可權控制練習儲存過程
- 【許可權】儲存過程執行時,報ORA-01031許可權不足儲存過程
- 呼叫者儲存過程訪問許可權問題儲存過程訪問許可權
- 儲存過程,角色相關的呼叫者許可權和定義者許可權問題儲存過程
- EXECUTE IMMEDIATE 儲存過程中 許可權不足及EXECUTE IMMEDIATE的除錯避坑儲存過程除錯
- 擁有GRANT ANY OBJECT PRIVILEGE許可權時的許可權回收Object
- 關於檢視和儲存過程的許可權問題探究儲存過程
- 儲存過程中使用Dbms_Scheduler包的許可權問題儲存過程
- all許可權使用者無法執行儲存過程儲存過程
- 在儲存過程中使用EXECUTE IMMEDIATE報許可權問題儲存過程
- MYSQL儲存過程許可權問題分析(Security_type詳解)MySql儲存過程
- Vim儲存時許可權不足
- Oracle角色許可權之Default RoleOracle
- oracle的儲存許可權的檢視Oracle
- 角色許可權(Role)和系統許可權(System)的幾個澄清實驗
- oracle實驗記錄 (許可權,role)Oracle
- 在儲存過程A中呼叫儲存過程B的結果儲存過程
- Sqlserver中的儲存過程SQLServer儲存過程
- 管理員能否revoke表擁有者delete表的許可權delete
- 查詢沒有許可權但資料字典中顯示有許可權
- win10提示您沒有許可權在此位置中儲存檔案的解決方法Win10
- 儲存過程中巢狀儲存過程的變數執行方式儲存過程巢狀變數
- 解決執行儲存過程出現許可權不足問題(ORA-01031)儲存過程
- PB中呼叫儲存過程儲存過程
- 儲存過程中拼接字串儲存過程字串
- java中呼叫儲存過程Java儲存過程
- Gate 超級管理員擁有全部許可權踩坑點
- Laravel 日誌有時候有許可權有時候沒有許可權?Laravel