成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

如何只授予用戶查看存儲過程定義的權(quán)限

數(shù)據(jù)庫 Oracle
本文對如何授予某個用戶只能查看某些存儲過程的定義權(quán)限,而不能讓用戶去修改、執(zhí)行存儲過程,進(jìn)行了梳理和總結(jié),供大家參考。

有個網(wǎng)友問我,如何授予某個用戶只能查看某些存儲過程的定義權(quán)限,而不能讓用戶去修改、執(zhí)行存儲過程。看似簡單的問題,卻因為從沒有碰到這樣的需求。花了點時間才梳理、總結(jié)清楚。

關(guān)于ORACLE賬號的權(quán)限問題,一般分為兩種權(quán)限:

系統(tǒng)權(quán)限: 允許用戶執(zhí)行特定的數(shù)據(jù)庫動作,如創(chuàng)建表、創(chuàng)建索引、創(chuàng)建存儲過程等

對象權(quán)限: 允許用戶操縱一些特定的對象,如讀取視圖,可更新某些列、執(zhí)行存儲過程等

像這種查看存儲過程定義的權(quán)限為對象權(quán)限,但是我們還是首先來看看關(guān)于存儲過程的系統(tǒng)權(quán)限吧:

 

  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 

 

如上所示,關(guān)于存儲過程的系統(tǒng)權(quán)限一般有六種: CREATE PROCEDURE、CREATE ANY PROCEDURE、 ALTER ANY PROCEDURE、DROP ANY PROCEDURE、 EXECUTE ANY PROCEDURE、DEBUG ANY PROCEDURE. 那么關(guān)于存儲過程的對象權(quán)限又有那些呢? 如下例子所示,在用戶ESCMUSER下創(chuàng)建存儲過程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用戶創(chuàng)建用戶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的所有權(quán)限授予給用戶TEMP。 那么我們發(fā)現(xiàn)存儲過程的對象權(quán)限只有EXECUTE、DEBUG權(quán)限

 

  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的權(quán)限從TEMP用戶收回,然后授予用戶TEMP關(guān)于存儲過程PROC_TEST的DEBUG權(quán)限

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

那么TEMP用戶此時執(zhí)行存儲過程報權(quán)限不足

  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權(quán)限不足問題。但是你可以在PL/SQL Developer工具或使用下面視圖查看存儲過程的定義。如下所示。

SELECT * FROM ALL_SOURCE WHERE NAME='PROC_TEST'

所以,只需要授予存儲過程的DEBUG權(quán)限給某個用戶,就可以實現(xiàn)只授予用戶查看存儲過程定義的權(quán)限,而限制用戶修改、執(zhí)行存儲過程。從而達(dá)到只授權(quán)用戶查看存儲過程定義的權(quán)限。不過這樣實現(xiàn),總讓我感覺有點怪怪的。

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

 

責(zé)任編輯:Ophira 來源: 博客園
相關(guān)推薦

2010-10-12 16:09:08

MySQL用戶權(quán)限

2010-10-12 16:02:00

MySQL用戶權(quán)限

2010-10-12 15:54:30

MySQL用戶權(quán)限

2021-12-27 10:56:10

MySQL數(shù)據(jù)庫命令

2014-10-24 09:55:12

FedoraDocker

2019-02-28 09:30:04

Ubuntusudo命令

2009-11-02 15:15:43

Oracle授予用戶權(quán)

2019-01-02 13:03:53

MySQL存儲權(quán)限

2018-04-18 09:18:44

數(shù)據(jù)庫MySQL存儲過程

2010-09-16 17:46:22

SQL存儲過程

2010-10-12 16:35:05

MySQL用戶權(quán)限

2023-12-20 10:14:24

2010-10-28 11:24:05

oracle用戶權(quán)限

2019-11-26 10:34:13

Linuxsudo權(quán)限命令

2010-07-09 12:22:42

SQL Server超

2010-06-07 21:01:45

管理員權(quán)限GPO

2010-10-14 09:52:35

MySQL命令行

2010-05-13 14:30:48

IIS服務(wù)器

2010-09-27 15:58:51

SQL存儲過程

2019-06-25 15:18:54

MySQL數(shù)據(jù)庫表層
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 国产97色 | 久久久久国产一区二区三区四区 | 亚洲精品综合 | 婷婷综合久久 | 午夜影院黄 | 狠狠操狠狠干 | 精品久久久久一区二区国产 | 中文字幕第十五页 | 国色天香综合网 | 成人影院在线视频 | 韩日一区 | 日韩一区二区三区在线观看 | 国产亚洲精品美女久久久久久久久久 | 欧美国产激情 | 91亚洲精华国产 | 国产2区 | 国产精品1区2区3区 一区中文字幕 | 日韩欧美不卡 | 成人av在线网站 | 福利精品| 黄色免费网站在线看 | 午夜精品视频 | 男人天堂午夜 | 精品久久国产 | 婷婷成人在线 | 国产中文字幕网 | 欧美精品一区在线 | 久久国产精品视频 | 欧美在线一区二区三区 | 国产做a爱免费视频 | 超碰精品在线 | 久久99精品久久久久 | 国产1区2区在线观看 | 成年免费在线观看 | 久久精品亚洲欧美日韩精品中文字幕 | xx性欧美肥妇精品久久久久久 | 国产目拍亚洲精品99久久精品 | 精品久久久久香蕉网 | 国产亚洲精品91 | 日本超碰 | 欧美videosex性极品hd |