`
123003473
  • 浏览: 1064689 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

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
分享到:
评论

相关推荐

    Oracle P/L SQL实现文件压缩、解压功能

    Create or Replace Package UTL_ZIP AUTHID CURRENT_USER as Type File_List is Table of Clob; --文件变成流 Function f_File2Blob( as_SubDir in VarChar2, as_FileName in VarChar2 )Return ...

    Oracle过程中创建视图

    - 使用`AUTHID CURRENT_USER`来确保过程中的所有操作都使用调用者的权限。 - 明确指定模式名称,如`EXECUTE IMMEDIATE 'CREATE OR REPLACE VIEW SCHEMA_NAME.VIEW_NAME AS SELECT * FROM SCHEMA_NAME.TABLE_NAME';`...

    oracle存储过程学习经典[语法+实例+调用]

    ### Oracle存储过程学习经典知识点详解 #### 一、Oracle存储过程概述 **存储过程**是在数据库中预先定义并编译好的一系列SQL语句或PL/SQL...理解并熟练掌握其使用方法对于任何从事数据库开发的人来说都是非常重要的。

    Oracle实现发送邮件

    ) AUTHID CURRENT_USER IS ``` ##### 邮件发送逻辑 为了构建邮件消息体,存储过程中定义了多个变量,包括用于存储邮件各个部分的字符串变量、文件读取相关的变量以及用于处理多部分消息(MIME类型)的变量。例如:...

    oracle存储过程学习经典[语法+实例+调用

    Oracle存储过程是构建在Oracle数据库中的一个独立的代码块,能够封装复杂的...总而言之,Oracle存储过程是数据库开发人员不可或缺的知识点,了解并熟练掌握其使用方法对提升数据库应用的性能与维护效率都有极大的帮助。

    oracle 存储过程学习

    ### Oracle 存储过程与函数详解 #### 6.1 引言 Oracle数据库中的存储过程和函数是PL/SQL编程的重要组成部分。它们是数据库中存储的命名块,可以...熟练掌握这两种工具的创建和使用方法对于Oracle开发者来说至关重要。

    Oracle经典语法的调用

    ### Oracle经典语法的调用——存储过程详解 #### 一、Oracle存储过程基础知识 存储过程是一种预先编写并存储于数据库中的SQL与编程语言混合的...理解并掌握Oracle存储过程的使用方法对于开发人员来说是非常重要的。

    Oracle事例

    from user_constraints c,user_cons_columns cc where c.owner = upper(\'&table_owner\') and c.table_name = upper(\'&table_name\') and c.owner = cc.owner and c.constraint_name = cc.constraint_name ...

    postgresql中文手册9.1

    - **基本概念**:SQL函数的基础知识和使用方法。 #### PL/pgSQL过程语言 - **概述**:介绍 PL/pgSQL 过程语言的基本特性和用途,包括变量声明、控制流语句等。 以上知识点基于 PostgreSQL 9.1 版本的手册进行了...

    ORACLE子程序及TABLE类型用法等[收集].pdf

    [ AUTHID {DEFINER | CURRENT_USER} ] [IS | AS] [ PRAGMA AUTONOMOUS_TRANSACTION; ] [local declarations] BEGIN executable statements [ EXCEPTION exception handlers ] END [name]; ``` 其中,`...

    oracle存储过程学习经典[语法+实例+调用].doc

    [authid {current_user | definer}] [IS|AS] pl_sql_subprogram_body [LANGUAGE {java name 'String' | c name, library lib_name}]; ``` 其中: - `CREATE OR REPLACE`:用于创建或替换已存在的同名存储过程。 - `...

    oracle 数据库 plsql 存储过程

    [authid {current_user | definer}] [IS | AS] { PL/SQL_subprogram_body | LANGUAGE {java name 'String' | c [name, name] library lib_name} }; ``` **示例**: ```sql CREATE OR REPLACE PROCEDURE sam....

    oracle 存储过程学习经典

    [AUTHID {CURRENT_USER | DEFINER}] {IS | AS} {pl_sql_subprogram_body | language{javaname 'String' | c [name, name] library lib_name}}; ``` #### 五、存储过程中的参数类型 - **IN**: 输入参数,用于向...

    Oracle存储过程学习经典[语法+实例+调用].

    [AUTHID {CURRENT_USER | DEFINER}] {IS | AS} {pl_sql_subprogram_body | LANGUAGE {JAVA | C}} ``` - **示例**: ```sql CREATE OR REPLACE PROCEDURE sam.credit ( acc_no IN NUMBER, amount IN NUMBER ...

    PL-SQL包的开发

    如果使用`CURRENT_USER`,则按照调用者的权限执行;如果使用`DEFINER`(默认),则按照定义者的权限执行。 - **调用说明**:允许在Oracle数据词典中发布Java方法或外部C函数。通过将程序的名称、参数类型和返回类型...

    OraclePlSql包(package).pdf

    如果选择CURRENT_USER,则子程序按照调用者权限执行,此时,模式对象的解析是在调用者的模式中进行的。 包体部分的可选初始化部分允许开发者初始化包中的变量等资源。此外,还可以通过调用说明发布Java方法或外部C...

Global site tag (gtag.js) - Google Analytics