ITPub博客

首页 > Linux操作系统 > Linux操作系统 > 详解Oracle用户权限视图的使用

详解Oracle用户权限视图的使用

原创 Linux操作系统 作者:lpwebnet 时间:2012-09-10 21:14:00 0 删除 编辑

本文将为大家介绍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可以生成这个角色。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/17172228/viewspace-743086/,如需转载,请注明出处,否则将追究法律责任。

上一篇: ORACLE 11G完美卸载
请登录后发表评论 登录
全部评论

注册时间:2012-07-21

  • 博文量
    120
  • 访问量
    845701