Oracle:Authid Current_User的使用(轉)
我們知道,使用者擁有的role許可權在儲存過程是不可用的。遇到這種情況,我們一般需要顯式授權,如grant create table to usera;但這種方法太麻煩,有時候可能需要進行非常多的授權才能執行儲存過程,實際上,oracle給我們提供了在儲存過程中使用role許可權的方法:修改儲存過程,加入Authid Current_User時儲存過程可以使用role許可權。下面來舉個例子:
SQL> select * from v$version;
BANNER
----------------------------------------------------------------
Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Prod
PL/SQL Release 10.2.0.1.0 - Production
CORE 10.2.0.1.0 Production
TNS for 32-bit Windows: Version 10.2.0.1.0 - Production
NLSRTL Version 10.2.0.1.0 - Production
----------------------------------------------------------------
Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Prod
PL/SQL Release 10.2.0.1.0 - Production
CORE 10.2.0.1.0 Production
TNS for 32-bit Windows: Version 10.2.0.1.0 - Production
NLSRTL Version 10.2.0.1.0 - Production
SQL> conn sjh/sjh
已連線。
SQL> create or replace procedure p_test
2 is
3 begin
4 execute immediate 'create table creat_table(id number)';
5 end;
6 /
已連線。
SQL> create or replace procedure p_test
2 is
3 begin
4 execute immediate 'create table creat_table(id number)';
5 end;
6 /
過程已建立。
SQL> exec p_test;
BEGIN p_test; END;
BEGIN p_test; END;
*
第 1 行出現錯誤:
ORA-01031: 許可權不足
ORA-06512: 在 "SJH.P_TEST", line 4
ORA-06512: 在 line 1
第 1 行出現錯誤:
ORA-01031: 許可權不足
ORA-06512: 在 "SJH.P_TEST", line 4
ORA-06512: 在 line 1
SQL>
SQL> select * from dba_role_privs where grantee='SJH';
GRANTEE GRANTED_ROLE ADM DEF
------------------------------ ------------------------------ --- ---
SJH RESOURCE NO YES
------------------------------ ------------------------------ --- ---
SJH RESOURCE NO YES
--實際上SJH使用者有resource的角色,也就是說有建表的許可權。
SQL> select * from dba_role_privs where grantee='SFX';
GRANTEE GRANTED_ROLE ADM DEF
------------------------------ ------------------------------ --- ---
SFX RESOURCE NO YES
SFX CONNECT NO YES
SFX PLUSTRACE NO YES
------------------------------ ------------------------------ --- ---
SFX RESOURCE NO YES
SFX CONNECT NO YES
SFX PLUSTRACE NO YES
SQL> create or replace procedure p_test
2 Authid Current_User
3 is
4 begin
5 execute immediate 'create table creat_table(id number)';
6 end;
7 /
2 Authid Current_User
3 is
4 begin
5 execute immediate 'create table creat_table(id number)';
6 end;
7 /
過程已建立。
SQL> exec p_test;
PL/SQL 過程已成功完成。
SQL> select * from creat_table;
未選定行
--在儲存過程加了Authid Current_User選項,表建立成功。
from :http://www.cnblogs.com/advocate/archive/2011/02/17/1957389.html
[@more@]
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/14844492/viewspace-1051796/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- oracle儲存過程中authid current_user和authid definerOracle儲存過程
- ORACLE 儲存過程中的Authid Current_UserOracle儲存過程
- 使用 Authid Current_User 為呼叫者授權
- AUTHID DEFINER\authid current_user與alter session set current_schemaSession
- 儲存過程許可權__Authid Current_User儲存過程
- Oracle 定義者許可權與呼叫者許可權(AUTHID CURRENT_USER)Oracle
- job中呼叫儲存過程,儲存過程使用AUTHID CURRENT_USER,還出現ORA-01031儲存過程
- @1-MYSQL當前使用者user()與current_user()MySql
- [轉]Oracle陣列的使用Oracle陣列
- [PL/SQL]Something about authid for proceduresSQL
- 轉載-oracle Shrink命令的使用Oracle
- oracle開發中序列的使用(轉)Oracle
- ORACLE使用經驗(轉)Oracle
- oracle opatch 工具的使用(oracle小補丁安裝)(轉)Oracle
- mysql5.5的一些函式_user()_current_user()MySql函式
- [轉]oracle 遊標使用大全Oracle
- Oracle Profile 使用詳解(轉)Oracle
- 使用Oracle to_date方法【轉】Oracle
- Oracle 遊標使用大全(轉)Oracle
- Oracle遊標使用大全(轉)Oracle
- 【轉載】oracle全文索引的建立和使用Oracle索引
- (轉)Oracle為什麼不使用我的索引?Oracle索引
- Oracle中分組查詢時keep的使用[轉][Oracle
- Oracle9i中監視索引的使用(轉)Oracle索引
- 【轉】oracle診斷工具-RDA使用Oracle
- oracle診斷工具-RDA使用(轉)Oracle
- 更改oracle使用者資訊(轉)Oracle
- 轉:Oracle Outline的使用及注意事項Oracle
- 破解Oracle一般使用者的口令(轉)Oracle
- 查詢 Oracle 使用者鎖的DLL SQL(轉)OracleSQL
- 【轉】使用oracle pipe傳遞訊息Oracle
- Oracle 分析函式使用介紹(轉)Oracle函式
- Oracle工具使用之SQLPLUS(轉)OracleSQL
- ORACLE使用者常用資料字典的查詢使用方法(轉)Oracle
- Oracle的預設使用者及其建立指令碼[轉]Oracle指令碼
- oracle 轉義字元去掉下劃線 _ 的使用方法Oracle字元
- 【轉】檢視Oracle當前使用者下的資訊Oracle
- AIX環境oracle使用者的.profile檔案(轉)AIOracle