Oracle之AUTHID CURRENT_USER 3

2024-06-23 14:18
文章标签 oracle authid current user

本文主要是介绍Oracle之AUTHID CURRENT_USER 3,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

3调用者的举例详解


没有AUTHID CURRENT_USER表示定义者权限(definer rights),以定义者身份执行;

加上AUTHID CURRENT_USER表示调用者权限(invoker rights),以调用者身份执行。

 

例:

 

1. 创建两个用户:xxpo,xxgl

2. 在xxpo下创建一张表:xxpo_authid_test

[c-sharp]  view plain copy
  1. CREATE TABLE xxpo.xxpo_authid_test(ID NUMBER,NAME VARCHAR2(20));  

3. 在xxpo下创建如下两个procedure

3.1 xxpo_no_authid_test_prc:

[c-sharp]  view plain copy
  1. CREATE OR REPLACE PROCEDURE xxpo_no_authid_test_prc  
  2. (  
  3.   p_id   IN NUMBER  
  4.  ,p_name IN VARCHAR2  
  5. ) IS  
  6. BEGIN  
  7.   INSERT INTO xxpo_authid_test  
  8.     (id  
  9.     ,NAME)  
  10.   VALUES  
  11.     (p_id  
  12.     ,p_name);  
  13. END xxpo_no_authid_test_prc;  

3.2 xxpo_has_authid_test_prc:

[c-sharp]  view plain copy
  1. CREATE OR REPLACE PROCEDURE xxpo_has_authid_test_prc  
  2. (  
  3.   p_id   IN NUMBER  
  4.  ,p_name IN VARCHAR2  
  5. ) AUTHID CURRENT_USER IS  
  6. BEGIN  
  7.   INSERT INTO xxpo_authid_test  
  8.     (id  
  9.     ,NAME)  
  10.   VALUES  
  11.     (p_id  
  12.     ,p_name);  
  13. END xxpo_has_authid_test_prc;  

4. 将两个procedure的执行权限(EXECUTE)赋予xxgl:

[c-sharp]  view plain copy
  1. SQL> GRANT EXECUTE ON xxpo_no_authid_test_prc TO xxgl;  
  2.    
  3. Grant succeeded  
  4. SQL> GRANT EXECUTE ON xxpo_has_authid_test_prc TO xxgl;  
  5.    
  6. Grant succeeded  

5. 在xxgl分别调用xxpo下面的两个procedure,查看结果:

[c-sharp]  view plain copy
  1. SQL> BEGIN  
  2.   2  xxpo.xxpo_no_authid_test_prc(1,'nameXXGL001');  
  3.   3  END;  
  4.   4  /  
  5.    
  6. PL/SQL procedure successfully completed  
  7.    
  8. SQL>   
  9. SQL> BEGIN  
  10.   2  xxpo.xxpo_has_authid_test_prc(2,'nameXXGL002');  
  11.   3  END;  
  12.   4  /  
  13.    
  14. BEGIN  
  15. xxpo.xxpo_has_authid_test_prc(2,'nameXXGL002');  
  16. END;  
  17.    
  18. ORA-00942: table or view does not exist  
  19. ORA-06512: at "XXPO.XXPO_HAS_AUTHID_TEST_PRC", line 7  
  20. ORA-06512: at line 3  
  21.    
  22. SQL> SELECT * FROM xxpo.xxpo_authid_test;  
  23.    
  24.         ID NAME  
  25. ---------- --------------------  
  26.          1 nameXXGL001  
  27.    
  28. SQL>   

由于我们并没有在xxgl用户下创建一个名为xxpo_authid_test的表,所以当我们在xxgl用户下以调用者(xxgl)权限去执行xxpo.xxpo_has_authid_test_prc这个procedure的时候,会报表不能找到(ORA-00942)的错误;而以定义者(xxpo)权限去执行则不存在此问题。


---

Authid Current_User 是调用者权限。
oracle DB下面有2种执行的权限:定义者权限和调用者权限。
默认都是定义者权限。声明Authid Current_User后就是调用者权限。定义者权限的现象是,如果在APPS下创建的procedure,那其他user,只要能执行procedure,都是以apps的名义来执行的。因为APPS是procedure的定义者。
APPS能做什么,那这个procedure就能做什么。调用者权限的现象是,如果在APPS下创建的procedure,如果其他user有权限执行这个procedure,这个procedure所做的内容都是以当前user的名义来做的。如果某个table,只有APPS才有权限修改,那这个procedure在apps下面才执行成功。其他user下是不成功的。

这篇关于Oracle之AUTHID CURRENT_USER 3的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1087391

相关文章

BD错误集锦9——查询hive表格时出错:Wrong FS: hdfs://s233/user/../warehouse expected: hdfs://mycluster

集群环境描述:HDFS集群处于HA模式下,同时启动了YARN\JN\KAFKA\ZK。 现象: FAILED: SemanticException Unable to determine if hdfs://s233/user/hive/warehouse/mydb.db/ext_calllogs_in_hbase is encrypted: java.lang.IllegalArgument

ORACLE 、达梦 数据库查询指定库指定表的索引信息

在Oracle数据库中,索引是一种关键的性能优化工具,通过它可以加快数据检索速度。在本文中,我们将深入探讨如何详细查询指定表的索引信息,以及如何利用系统视图和SQL查询来获取这些信息。 索引在数据库中的重要性 索引是一种数据结构,用于加快数据库表中数据的检索速度。它类似于书籍的目录,可以帮助数据库引擎快速定位数据行,特别是在大型数据集合下,其作用尤为显著。 查询指定表的索引信息 在Orac

oracle数据导出txt及导入txt

oracle数据导出txt及导入txt ORACLE数据导出TXT及从TXT导入: 导出到TXT文件: 1、用PL/SQL DEV打开CMD窗口。 2、spool d:/output.txt; 3、set heading off; --去掉表头 4、select * from usergroup; 5、spool off; www.2ct

Linux开机自动启动ORACLE设置

Redhat init简介: Linux启动时,会运行一个init程序,然后由init来启动后面的任务,包括多用户环境(inittab中设定)和网络等。运行级就是当前程序运行的功能级别,这个级别从1到6,具有不同的功能。这些级别在/etc/inittab(其他发行版这个文件位置不同)中指定,该文件就是init程序寻找的主要文件。最先运行的服务放在/etc/rc.d目录下。

red hat enterprise 下完全删除oracle 数据库

步骤 1     以 oracle 用户登录主、备节点。 步骤 2     关闭 数据库 监听。 > lsnrctl stop 步骤 3     关闭数据库 实例 。 > sqlplus '/as sysdba' > shutdown immediate 步骤 4     以root用户登录数据库 服务器 。 步骤 5     删除Oracle用户。 # userdel -r or

如何查看和修改Oracle数据库服务器端的字符集

Oracle数据库查看和修改服务器端的字符集的方法是本文主要要介绍的内容,接下来救让我们一起来了解一下这部分内容。 A、oracle server 端字符集查询 select userenv(‘language’) from dual 其中NLS_CHARACTERSET 为server端字符集 NLS_LANGUAGE 为 server端字符显示形式 B、查询oracle

linux cron /etc/crontab 及 /var/spool/cron/$USER 中定义定时任务

简介 定时任务在linux上主要体现在两个地方,一个是/etc/crontab ,另一个就是定义了任务计划的用户/var/spool/cron/$USER 1、crontab -e 或者直接编辑/etc/crontab文件,这种方式用的人比较多,/etc/crontab是系统调度的配置文件,只有root用户可以使用,使用时需root权限,而且必须指定运行用户,才会执行 * * * * * *

在 Oracle Linux 8.9 上安装中文和日文字体的完整指南

在 Oracle Linux 8.9 上安装中文和日文字体的完整指南 在 Oracle Linux 8.9 上安装中文和日文字体的完整指南前提条件安装步骤1. 更新系统2. 安装字体包安装中文字体安装日文字体 3. 安装字体配置工具4. 更新字体缓存5. 验证安装 可能遇到的问题及解决方案结语 在 Oracle Linux 8.9 上安装中文和日文字体的完整指南 在使用 Ora

oracle创建一个带参数的存储过程:为指定的员工,涨100块钱的工资;并且打印涨前和涨后的薪水

--创建一个带参数的存储过程--为指定的员工,涨100块钱的工资;并且打印涨前和涨后的薪水/*beginraisesalary(6755);raisesalary(4456);commit();//这里提交,所以说我们一般不会在存储过程或者存储函数中写提交,end;/*/--host cls--先创建表emp和插入数据,显示表的结构用desc 表名--create table empcr

oracle学习之第一个存储过程:打印Hello World

数据库对象:表、视图、索引、序列、同义词、存储过程、存储函数 存储过程:指的是存储在数据库中供所有用户程序调用的子程序叫存储过程、存储函数 存储过程和存储函数的相同点:完成特定功能的程序 存储过程和存储函数的区别:是否用return语句返回值(存储函数可以,但是存储过程不行) --第一个存储过程:打印Hello World/*调用存储过程2种方式:1、exec sayhellow