返回顶部
首页 > 资讯 > 数据库 >oracle中怎么只授予用户查看存储过程定义的权限
  • 250
分享到

oracle中怎么只授予用户查看存储过程定义的权限

2024-04-02 19:04:59 250人浏览 薄情痞子
摘要

这篇文章主要介绍了oracle中怎么只授予用户查看存储过程定义的权限,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。关于ORACLE账号的权限

这篇文章主要介绍了oracle中怎么只授予用户查看存储过程定义的权限,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

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

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

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

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

PRIVILEGE NAME                                       PROPERTY  --------- ---------------------------------------- ----------       -140 CREATE PROCEDURE                                  0       -141 CREATE ANY PROCEDURE                              0       -142 ALTER ANY PROCEDURE                               0       -143 DROP ANY PROCEDURE                                0       -144 EXECUTE ANY PROCEDURE                             0       -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

CREATE OR REPLACE PROCEDURE ESCMUSER.PROC_TEST  AS  BEGIN     DBMS_OUTPUT.PUT_LINE('It is only test');  END;

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

sql> create user temp identified by temp;  User created.  SQL> grant connect,resource to temp;  Grant succeeded.

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

SQL> COL GRANTEE FOR A12;  SQL> COL TABLE_NAME FOR A30;  SQL> COL GRANTOR FOR A12;  SQL> COL PRIVILEGE FOR A8;  SQL> SELECT * FROM USER_TAB_PRIVS_MADE WHERE GRANTEE='TEMP';   GRANTEE      TABLE_NAME              GRANTOR      PRIVILEGE               GRA HIE  ---------- --------------------- ------------ --------------------------- --- ---  TEMP         PROC_TEST                ESCMUSER     DEBUG                   NO  NO  TEMP         PROC_TEST                ESCMUSER     EXECUTE                 NO  NO   SQL>

oracle中怎么只授予用户查看存储过程定义的权限

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

SQL>REVOKE ALL ON PROC_TEST FROM TEMP;  SQL>GRANT DEBUG ON PROC_TEST TO TEMP;

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

SQL> SET SERVEROUT ON;  SQL> EXEC escmuser.proc_test;  begin escmuser.proc_test; end;  ORA-06550: line 2, column 16:  PLS-00904: insufficient privilege to access object ESCMUSER.PROC_TEST  ORA-06550: line 2, column 7:  PL/SQL: Statement ignored

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

SELECT * FROM ALL_SOURCE WHERE NAME='PROC_TEST'

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

感谢你能够认真阅读完这篇文章,希望小编分享的“oracle中怎么只授予用户查看存储过程定义的权限”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网数据库频道,更多相关知识等着你来学习!

您可能感兴趣的文档:

--结束END--

本文标题: oracle中怎么只授予用户查看存储过程定义的权限

本文链接: https://lsjlt.com/news/61048.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作