程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle數據庫基礎 >> 詳解Oracle用戶權限視圖的使用

詳解Oracle用戶權限視圖的使用

編輯:Oracle數據庫基礎

本文將為大家介紹Oracle用戶權限視圖的使用方法,包括一些Oracle用戶權限視圖的命令等。希望能對大家日常數據庫維護有所幫助。

查看當前用戶:SQL>select  user from dual;

一. Oracle用戶權限視圖概述

與權限,角色相關的視圖大概有下面這些:

DBA_SYS_PRIVS: 查詢某個用戶所擁有的系統權限

USER_SYS_PRIVS: 當前用戶所擁有的系統權限

SESSION_PRIVS: 當前用戶所擁有的全部權限

ROLE_SYS_PRIVS: 某個角色所擁有的系統權限

注意: 要以SYS用戶登陸查詢這個視圖,否則返回空.

ROLE_ROLE_PRIVS: 當前角色被賦予的角色

SESSION_ROLES: 當前用戶被激活的角色

USER_ROLE_PRIVS: 當前用戶被授予的角色

另外還有針對表的訪問權限的視圖:

TABLE_PRIVILEGES

ALL_TAB_PRIVS

ROLE_TAB_PRIVS: 某個角色被賦予的相關表的權限

...

二.Examples

1.查詢當前用戶所擁有的權限

  1. Select * from session_privs; 

2.查詢某個用戶被賦予的系統權限:

可以有多種方式

  1. Select * from user_sys_privs; 

或者: select * from DBA_SYS_PRIVS where grantee='XXX'

(需要當前用戶擁有DBA角色)

3.查詢當前用戶被授予的角色:

  1. Select * from SESSION_ROLES order by ROLE 

說明: 這個查詢會返回當前用戶所被授予的全部角色, 其中包括

嵌套授權的角色. 例如將DBA角色授予了一個用戶,DBA角色

已經被授予的角色(例如 exp_full_database 和 imp_full_database)

也會被查詢出來

  1. Select * from USER_ROLE_PRIVS 

4.查詢某一角色被賦予的系統權限

  1. Select Privilege from ROLE_SYS_PRIVS where ROLE=&Role 

輸入 role='CONNECT'

輸出:

  1. PRIVILEGE  
  2. --------------------  
  3. ALTER SESSION  
  4. CREATE CLUSTER  
  5. CREATE DATABASE LINK  
  6. CREATE SEQUENCE 
  7. CREATE SESSION  
  8. CREATE SYNONYM  
  9. CREATE TABLE 
  10. CREATE VIEW 

5. 查詢當前角色被授予的角色

  1. Select GRANTED_ROLE from ROLE_ROLE_PRIVS where ROLE=&ROLE 

輸入 role= 'DBA'

輸出:

  1. GRANTED_ROLE  
  2. ----------------------  
  3. DELETE_CATALOG_ROLE  
  4. EXECUTE_CATALOG_ROLE  
  5. EXP_FULL_DATABASE  
  6. IMP_FULL_DATABASE  
  7. PLUSTRACE  
  8. SELECT_CATALOG_ROLE 

說明: PLUSTRACE這個角色是用於執行SQL AUTO TRACE的, 通過執行

$Oracle_HOME/sqlplus/admin/plustrce.sql可以生成這個角色。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved