当前位置 : 主页 > 编程语言 > java >

Authid current_user的用法

来源:互联网 收集:自由互联 发布时间:2022-09-02
Authid Current_User:以执行过程的用户的权限来处理涉及的对象权限. 这是典型的,数据库中只创建一个存储过程,所有用户都可以使用,但是每个用户使用的时候 只是用自己的权限权限执


Authid Current_User:以执行过程的用户的权限来处理涉及的对象权限. 

这是典型的,数据库中只创建一个存储过程,所有用户都可以使用,但是每个用户使用的时候 只是用自己的权限权限执行,oracle自己的包很多都这样的。 

存储过程默认是用定义者definer 的身份调用的,如果加上AUTHID CURRENT_USER,则用当前登陆的用户权限调用,如果该过程的调用者(而非定义者)被授与系统权限execute any procedure或是被该过程的定义者grant execute on授权的话,不用这个AUTHID CURRENT_USER子句,调用者照样可以使用这个过程。 
另外,在Oracle的存儲過程中,如果涉及到操作不同schema下的對象的時候,可以在不同的schema下寫相同的procedure,但這樣帶來的問題是維護和同步帶來了麻煩,可以在procedure中加上authid current_user,來說明procedure中操作的對象是當前連接用戶的對象而并不是procedure所屬用戶下的對象。 

一个例子


引用:

create or replace procedure pr_mv is 
begin 
DBMS_MVIEW.REFRESH('mv_xx'); 
end;




存储过程中调用,test存储过程时会提示:ora-01031 权限不足 

这里是调用者对这个MV的权限可能不够,


引用:

create or replace procedure pr_mv 
authid current_user  is 
begin 
DBMS_MVIEW.REFRESH('mv_xx'); 
end; 




这样就OK

 

上一篇:HDU.2188 选拔志愿者
下一篇:没有了
网友评论