社区编辑申请
注册/登录
如何只授予用户查看存储过程定义的权限
数据库 Oracle
本文对如何授予某个用户只能查看某些存储过程的定义权限,而不能让用户去修改、执行存储过程,进行了梳理和总结,供大家参考。

有个网友问我,如何授予某个用户只能查看某些存储过程的定义权限,而不能让用户去修改、执行存储过程。看似简单的问题,却因为从没有碰到这样的需求。花了点时间才梳理、总结清楚。

关于ORACLE账号的权限问题,一般分为两种权限:

系统权限: 允许用户执行特定的数据库动作,如创建表、创建索引、创建存储过程等

对象权限: 允许用户操纵一些特定的对象,如读取视图,可更新某些列、执行存储过程等

像这种查看存储过程定义的权限为对象权限,但是我们还是首先来看看关于存储过程的系统权限吧:

 

  1. PRIVILEGE NAME                                       PROPERTY 
  2.  
  3. --------- ---------------------------------------- ---------- 
  4.  
  5.      -140 CREATE PROCEDURE                                  0 
  6.  
  7.      -141 CREATE ANY PROCEDURE                              0 
  8.  
  9.      -142 ALTER ANY PROCEDURE                               0 
  10.  
  11.      -143 DROP ANY PROCEDURE                                0 
  12.  
  13.      -144 EXECUTE ANY PROCEDURE                             0 
  14.  
  15.      -241 DEBUG ANY PROCEDURE                               0 

 

如上所示,关于存储过程的系统权限一般有六种: CREATE PROCEDURE、CREATE ANY PROCEDURE、 ALTER ANY PROCEDURE、DROP ANY PROCEDURE、 EXECUTE ANY PROCEDURE、DEBUG ANY PROCEDURE. 那么关于存储过程的对象权限又有那些呢? 如下例子所示,在用户ESCMUSER下创建存储过程PROC_TEST

 

  1. CREATE OR REPLACE PROCEDURE ESCMUSER.PROC_TEST 
  2.  
  3. AS 
  4.  
  5. BEGIN  
  6.  
  7.   DBMS_OUTPUT.PUT_LINE('It is only test'); 
  8.  
  9. END

 

使用system用户创建用户TEMP,如下所示

 

  1. SQL> create user temp identified by temp
  2.  
  3. User created. 
  4.  
  5. SQL> grant connect,resource to temp
  6.  
  7. Grant succeeded. 

 

在用户ESCMUSER下将存储过程PROC_TEST的所有权限授予给用户TEMP。 那么我们发现存储过程的对象权限只有EXECUTE、DEBUG权限

 

  1. SQL> COL GRANTEE FOR A12; 
  2.  
  3. SQL> COL TABLE_NAME FOR A30; 
  4.  
  5. SQL> COL GRANTOR FOR A12; 
  6.  
  7. SQL> COL PRIVILEGE FOR A8; 
  8.  
  9. SQL> SELECT * FROM USER_TAB_PRIVS_MADE WHERE GRANTEE='TEMP'
  10.  
  11.  
  12. GRANTEE      TABLE_NAME              GRANTOR      PRIVILEGE               GRA HIE 
  13.  
  14. ---------- --------------------- ------------ --------------------------- --- --- 
  15.  
  16. TEMP         PROC_TEST                ESCMUSER     DEBUG                   NO  NO 
  17.  
  18. TEMP         PROC_TEST                ESCMUSER     EXECUTE                 NO  NO 
  19.  
  20.  
  21. SQL>  

将存储过程PORC_TEST的权限从TEMP用户收回,然后授予用户TEMP关于存储过程PROC_TEST的DEBUG权限

  1. SQL>REVOKE ALL ON PROC_TEST FROM TEMP
  2.  
  3. SQL>GRANT DEBUG ON PROC_TEST TO TEMP

那么TEMP用户此时执行存储过程报权限不足

  1. SQL> SET SERVEROUT ON
  2.  
  3. SQL> EXEC escmuser.proc_test; 
  4.  
  5. begin escmuser.proc_test; end
  6.  
  7. ORA-06550: line 2, column 16: 
  8.  
  9. PLS-00904: insufficient privilege to access object ESCMUSER.PROC_TEST 
  10.  
  11. ORA-06550: line 2, column 7: 
  12.  
  13. PL/SQL: Statement ignored 

此时,如果修改存储过程PROC_TEST就会ORA-01031权限不足问题。但是你可以在PL/SQL Developer工具或使用下面视图查看存储过程的定义。如下所示。

SELECT * FROM ALL_SOURCE WHERE NAME='PROC_TEST'

所以,只需要授予存储过程的DEBUG权限给某个用户,就可以实现只授予用户查看存储过程定义的权限,而限制用户修改、执行存储过程。从而达到只授权用户查看存储过程定义的权限。不过这样实现,总让我感觉有点怪怪的。

原文链接:http://www.cnblogs.com/kerrycode/p/4580256.html

 

责任编辑:Ophira 来源: 博客园
相关推荐

2022-05-09 15:08:56

存储厂商NFV领域华为

2010-10-12 16:09:08

MySQL用户权限

2010-10-12 16:02:00

MySQL用户权限

2022-04-12 14:11:27

存储虚拟化软件定义服务器

2022-05-25 10:49:02

云存储云计算

2021-12-27 10:56:10

2022-05-25 10:04:43

Go编程

2022-04-01 10:08:21

SQL 优化MySQL数据库

2022-02-16 08:45:55

Vue-Router权限管理系统权限验证

2022-04-21 10:18:04

用友BIPPaaS

2022-04-26 08:00:00

存储UFSeMMC

2022-05-07 10:09:01

开发Java日志

2009-11-02 15:15:43

Oracle授予用户权

2022-05-16 10:49:28

网络协议数据

2022-05-23 09:18:55

RocketMQ存储中间件

2022-05-12 07:37:51

单点登录微服务开源

2022-05-08 23:13:43

零信任网络安全

2022-05-20 14:08:13

Web3元宇宙区块链

2022-05-23 10:46:52

苹果iOS 15.5更新

2022-05-13 09:27:55

Widget机票业务App

编辑推荐

Oracle免费的便捷Web应用开发框架二则Oracle数据库初学者开场篇ORACLE数据库异步IO介绍一次去重 80w 数据时夯死临时处理实例如何只授予用户查看存储过程定义的权限
我收藏的内容
点赞
收藏

51CTO技术栈公众号