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










