存儲過程授權
㈠ sql2008新建用戶XKY,如何給它創建、修改、查看、執行存儲過程的許可權
GRANT CREATE,MODIFY,SELECT,EXECUTE ON dbo.procname TO XKY; //所有許可權。
㈡ oracle賦權調用存儲過程
首先,需要resource,connect
grant resource,connect to guest;
然後賦予 執行許可權(對每一個存儲過程授權):
grant execute on cache.xxxxxx to guest
㈢ oracle存儲過程許可權有哪些
Oracle 存儲過程(Stored Procere)是一段預定義的程序,可以被存儲在資料庫中並在稿指需要時被調用執行。與其他程序一樣,存儲過程需要適當的許可權設置,以便只有授權用戶才能訪問和執行它。下面是 Oracle 存儲過程常用的許可權:
CREATE PROCEDURE 許可權:允許用戶創建存儲過程。
ALTER PROCEDURE 許可權:允許用戶修改已經存在的存儲過程。
EXECUTE 許可權:允許用納敬穗戶執行存儲過程。
DEBUG CONNECT SESSION 許可權:允許用戶調試存儲過程,包括在運行過程中進行斷點調試和監控變數等。
DEBUG ANY PROCEDURE 許可權:允許用戶調試資料庫中任何存儲過程。
DEBUG ANY PROGRAM 許可權:允許用戶調試資料庫中任何程序。
DROP PROCEDURE 許可權:允許用戶刪除已經存在的存儲過程。
需要注意的是,對於存儲過程的許可權設置,應該根據實際情況進行授權,只授予必要的許可權以保證數據的安全性和完整性。例如,只有特定的用戶才能執行存儲過程,而其他用戶無法訪問存儲過程的代碼和洞卜結果。同時,還需要定期檢查資料庫中存儲過程的許可權設置,以確保其符合安全和合規要求。
㈣ 查看存儲過程內容的許可權怎麼給
你好,這個的話只需要授予存儲過程的debug許可權給某個用戶,就可以實現只授予用戶查看存儲過程定義的許可權,而限制用戶修改、執行存儲過程。從而達到只授權用戶查看存儲過程定義的許可權。
㈤ 怎樣授權存儲過程給另外一個用戶
一般是對於存儲過程授執行權權
Grant execute on procere_name to user1;
如果要求被授權用戶也能夠授權給其它用戶:
grant execute on procere_name to user1 with grant option;
數據存儲是數據流在加工過程中產生的臨時文件或加工過程中需要查找的信息。數據以某種格式記錄在計算機內部或外部存儲介質上。數據存儲要命名,這種命名要反映信息特徵的組成含義。
㈥ 如何實現只授予用戶查看存儲過程定義的許可權
如何授予某個用戶只能查看某些存儲過程的定義許可權,而不能讓用戶去修改、執行存儲過程。看似簡單的問題,卻因為從沒有碰到這樣的需求。花了點時間才梳理、總結清楚。
關於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_TESTASBEGINDBMS_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 NOTEMP PROC_TEST ESCMUSER EXECUTE NO NOSQL>將存儲過程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_TESTORA-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怎麼只給存儲過程授權執行許可權不給看的許可權
存儲過程的相關許可權一共只有兩個,一個是excute許可權,還有一個是debug許可權。
按照你的說法就是只給excute的許可權,不給debug許可權,因為沒試過這樣能不能查看,所以你要自己試驗下才行。