Welcome to the website navigation,本站只接受合法正规的企业网站,欢迎站长们提交你的网站获得展示和流量有任何问题请联系站长,欢迎大家加入本站。

                
提交网站
  • 网站:76083
  • 待审:5
  • APP:577
  • 文章:304416
  • 会员:56004
文字内链包年1000元 文字内链包年1000元 文字内链包年1000元 AI办公网站 AI绘画工具 AIchat

名站网址导航为大家提供关于数据库教程相关的教程网站知识。

oracle(plsql)生成流水号gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

复制具体相关代码 具体相关代码如下:,CREATE OR REPLACE FUNCTION fn_no_make(v_prefix     VARChAR2,                                       v,  v_sql := 'SELECT TO_ChAR(SYSDATE,''YYYYMMDD'') FROM DUAL';   EXECUTE IMMEDIATE v_sql INTO v_date_n,  v_old_num := to_number(substr(v_old_no, 12, 3));   v_new_num := lpad(to_char(v_old_num 1), 3, '0'),  IF v_old_no IS NULL OR substr(v_old_no, 3, 8) <> v_date_no ThEN     v_new_no := v_prefix || v_date,  RETURN v_new_no; EXCEPTION   WhEN OThERS ThEN     dbms_output.put_line(SQLERRM); END fn_no_make;,gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

本文对如何授予某个用户只能查看某些存储过程的定义权限,而不能让用户去修改、执行存储过程,进行了梳理和总结,供大家参考。gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

有个网友问我,如何授予某个用户只能查看某些存储过程的定义权限,而不能让用户去修改、执行存储过程。看似简单的问题,却因为从没有碰到这样的需求。花了点时间才梳理、总结清楚。gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

关于ORACLE账号的权限问题,一般分为两种权限:gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

系统权限:gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

允许用户执行特定的网站数据库动作,如创建表、创建索引、创建存储过程等gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

对象权限:gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

允许用户操纵一些特定的对象,如读取视图,可更新某些列、执行存储过程等gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

像这种查看存储过程定义的权限为对象权限,但是咱们还是首先来看看关于存储过程的系统权限吧:gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

 gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

 
  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_TESTgGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

 gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

 
  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,如下所示gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

 gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

 
  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权限gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

 gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

 
  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> 

gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

将存储过程PORC_TEST的权限从TEMP用户收回,然后授予用户TEMP关于存储过程PROC_TEST的DEBUG权限gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

 gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

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

那么TEMP用户此时执行存储过程报权限不足gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

 gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

 
  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相关工具或使用下面视图查看存储过程的定义。如下所示。gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

 gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

 
  1. SELECT * FROM ALL_SOURCE WhERE NAME='PROC_TEST' 

所以,只需要授予存储过程的DEBUG权限给某个用户,就可以实现只授予用户查看存储过程定义的权限,而限制用户修改、执行存储过程。从而达到只授权用户查看存储过程定义的权限。不过这样实现,总让我感觉有点怪怪的。gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

以上就是小编为大家整理的如何实现只授予用户查看存储过程定义的权限,希望可以对大家的学习能有所帮助。gGlAIChat_企业网址导航_网址分类目录_企业黄页网址提交查询专业网站!

关于数据库教程相关的教程网站知识今天我们就说到这里了,希望可以帮到大家。

标签:

分享到:

  网友投稿

注册时间:

网站:0 个   APP:0 个  文章:0 篇

  • 76083

    网站

  • 577

    APP

  • 304416

    文章

  • 56004

    会员

赶快注册账号,推广您的网站吧!
文章分类
热门网站
最新入驻APP小程序

宝贝市场2023-02-08

宝贝市场——买手和卖家商品展示

夺宝助手2023-02-08

夺宝助手小程序,查看每日快夺宝平

查诚信2023-02-08

查诚信是一款免费的商业查询工具

车价天天报2023-02-08

快速连接汽车销售,获知汽车最新报

考勤助理小程序2023-02-08

上班签到考勤,实时定位,后台轻松

汽车报价大全查询2023-02-08

汽车报价大全查询提供最新汽车市