Authid current_user的用法
来源:互联网 发布:guy里guy气网络用语 编辑:程序博客网 时间:2024/05/21 11:04
转载自:http://blog.csdn.net/inthirties/article/details/4673262
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
0 0
- Authid current_user的用法
- Authid current_user的用法
- Authid current_user的用法
- Authid Current_User的使用
- Authid Current_User的使用
- Authid Current_User的使用
- plsql程序Authid Current_User用法
- plsql程序Authid Current_User用法
- Oracle:Authid Current_User的使用
- Oracle:Authid Current_User的使用
- Oracle:Authid Current_User的使用
- Oracle:Authid Current_User的使用
- Oracle:Authid Current_User的使用
- Oracle:Authid Current_User的使用
- Oracle:Authid Current_User的使用(2)
- Oracle:Authid Current_User的使用2
- Oracle之AUTHID CURRENT_USER
- oracle Authid Current_User
- [ACdream原创群赛(12)のBUAA选拔赛]E:签到
- Java 理论与实践: 正确使用 Volatile 变量
- BlueJ的code pad
- ORACLE分析函数(1)
- DAS SEMQ优化
- Authid current_user的用法
- 股市基础知识、主力建仓【一】
- nodejs相关
- POJ 2253-Frogger (Prim)
- 递归(以及几个关于递归的小例子)
- ORACLE 几个常用的函数
- QML官方系列教程——Qt Quick Layouts
- 解决like中无法匹配下划线的问题
- 提问20140613