oracle invalid identifier,Oracle:Authid Current_User使用

 2023-11-19 阅读 12 评论 0

摘要:??? 由于用戶擁有的role權限在存儲過程是不可用的。遇到這種情況,我們一般需要顯示授權,如grant create table to user;但這種方法太麻煩,有時候可能需要進行非常多的授權才能執行存儲過程,實際上,oracle給我們提供了在存儲過程中使用role

??? 由于用戶擁有的role權限在存儲過程是不可用的。遇到這種情況,我們一般需要顯示授權,如grant create table to user;但這種方法太麻煩,有時候可能需要進行非常多的授權才能執行存儲過程,實際上,oracle給我們提供了在存儲過程中使用role權限的方法:修改存儲過程,加入Authid Current_User時存儲過程可以使用role權限。

oracle invalid identifier,??? 下面以例子說明:

----執行存儲過程p_create_emp2報下面的錯誤:
SQL> exec p_create_emp2;begin p_create_emp2; end;ORA-01031: 權限不足
ORA-06512: 在 "ECHO.P_CREATE_EMP2", line 12
ORA-06512: 在 line 2----查看p_create_emp2,該存儲過程是要創建emp2表
create or replace procedure P_create_emp2 ascursor t_cursor isselect * from user_tables where table_name = 'EMP2';t_cur t_cursor%rowtype;num int:=0;
beginfor t_cur in t_cursor loopnum:=num+1;end loop;if num=1 thenexecute immediate 'drop table emp2 purge';execute immediate 'create table emp2 as select * from emp';elseexecute immediate 'create table emp2 as select * from emp';end if;
end P_create_emp2;----查看echo用戶的角色或權限
SQL> select * from dba_role_privs where grantee='ECHO';GRANTEE                        GRANTED_ROLE                   ADMIN_OPTION DEFAULT_ROLE
------------------------------ ------------------------------ ------------ ------------
ECHO                           DBA                            NO           YES
----有dba的角色,說明建表的權限----修改存儲過程p_create_emp2:
create or replace procedure P_create_emp2 authid current_user ascursor t_cursor isselect * from user_tables where table_name = 'EMP2';t_cur t_cursor%rowtype;num int:=0;
beginfor t_cur in t_cursor loopnum:=num+1;end loop;if num=1 thenexecute immediate 'drop table emp2 purge';execute immediate 'create table emp2 as select * from emp';elseexecute immediate 'create table emp2 as select * from emp';end if;
end P_create_emp2;----再次執行:
SQL> exec p_create_emp2;PL/SQL procedure successfully completedSQL> desc emp2;
Name     Type         Nullable Default Comments 
-------- ------------ -------- ------- -------- 
EMPNO    NUMBER(4)    Y                         
ENAME    VARCHAR2(10) Y                         
JOB      VARCHAR2(9)  Y                         
MGR      NUMBER(4)    Y                         
HIREDATE DATE         Y                         
SAL      NUMBER(7,2)  Y                         
COMM     NUMBER(7,2)  Y                         
DEPTNO   NUMBER(2)    Y                ----在存儲過程加了Authid Current_User選項,表創建成功。

?

Oracle 不等于、轉載于:https://www.cnblogs.com/Richardzhu/p/3460985.html

版权声明:本站所有资料均为网友推荐收集整理而来,仅供学习和研究交流使用。

原文链接:https://hbdhgg.com/5/181302.html

发表评论:

本站为非赢利网站,部分文章来源或改编自互联网及其他公众平台,主要目的在于分享信息,版权归原作者所有,内容仅供读者参考,如有侵权请联系我们删除!

Copyright © 2022 匯編語言學習筆記 Inc. 保留所有权利。

底部版权信息