详解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可以生成这个角色。

当前名称:详解Oracle用户权限视图的使用
标题来源:http://www.shufengxianlan.com/qtweb/news44/48544.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联