您的位置:首页 > 数据库 > Oracle

oracle的系统和对象权限 查看用户包含的各类权限

2016-07-26 14:43 537 查看
查看某个用户在某个对象的权限,可以查dba_tab_privs 或者user_tab_privs

 

如下:某普通用户登陆,查自己的角色
SQL> select * from user_role_privs;
 

查自己拥有哪些系统权限

SQL> select * from session_privs;
查自己可以访问对象的权限

    
SQL>select * from user_tab_privs;
 

用sys用户查某用户的系统权限

SQL> select * from dba_sys_privs where grantee='LHOMSMD';

GRANTEE PRIVILEGE ADM

------------------------------ ---------------------------------------- ---

LHOMSMD DEBUG CONNECT SESSION NO

LHOMSMD UNLIMITED TABLESPACE NO
用户的角色
SQL> select * from dba_role_privs where grantee='LHOMSMD';
 

用户的对象权限
SQL> select * from dba_tab_privs where grantee='LHOMSMD' and privilege='EXECUTE'
 

其他相关权限安全的数据字典表有:

  ALL_TAB_PRIVS

  ALL_TAB_PRIVS_MADE

  ALL_TAB_PRIVS_RECD

  DBA_SYS_PRIVS

  DBA_ROLES

  DBA_ROLE_PRIVS

  ROLE_ROLE_PRIVS

  ROLE_SYS_PRIVS

  ROLE_TAB_PRIVS

  SESSION_PRIVS

  SESSION_ROLES

  USER_SYS_PRIVS

  USER_TAB_PRIV

http://space.itpub.net/12778571/viewspace-426953

 

oracle的系统和对象权限

  本文转自: http://hi.baidu.com/zhaojing_boy/blog/item/0ffe95091266d939e824885f.html

       alter any cluster 修改任意簇的权限

  alter any index 修改任意索引的权限

  alter any role 修改任意角色的权限

  alter any sequence 修改任意序列的权限

  alter any snapshot 修改任意快照的权限

  alter any table 修改任意表的权限

  alter any trigger 修改任意触发器的权限

  alter cluster 修改拥有簇的权限

  alter database 修改数据库的权限

  alter procedure 修改拥有的存储过程权限

  alter profile 修改资源限制简表的权限

  alter resource cost 设置佳话资源开销的权限

  alter rollback segment 修改回滚段的权限

  alter sequence 修改拥有的序列权限

  alter session 修改数据库会话的权限

  alter sytem 修改数据库服务器设置的权限

  alter table 修改拥有的表权限

  alter tablespace 修改表空间的权限

  alter user 修改用户的权限

  analyze 使用analyze命令分析数据库中任意的表、索引和簇

  audit any 为任意的数据库对象设置审计选项

  audit system 允许系统操作审计

  backup any table 备份任意表的权限

  become user 切换用户状态的权限

  commit any table 提交表的权限

  create any cluster 为任意用户创建簇的权限

  create any index 为任意用户创建索引的权限

  create any procedure 为任意用户创建存储过程的权限

  create any sequence 为任意用户创建序列的权限

  create any snapshot 为任意用户创建快照的权限

  create any synonym 为任意用户创建同义名的权限

  create any table 为任意用户创建表的权限

  create any trigger 为任意用户创建触发器的权限

  create any view 为任意用户创建视图的权限

  create cluster 为用户创建簇的权限

  create database link 为用户创建的权限

  create procedure 为用户创建存储过程的权限

  create profile 创建资源限制简表的权限

  create public database link 创建公共数据库链路的权限

  create public synonym 创建公共同义名的权限

  create role 创建角色的权限

  create rollback segment 创建回滚段的权限

  create session 创建会话的权限

  create sequence 为用户创建序列的权限

  create snapshot 为用户创建快照的权限

  create synonym 为用户创建同义名的权限

  create table 为用户创建表的权限

  create tablespace 创建表空间的权限

  create user 创建用户的权限

  create view 为用户创建视图的权限

  delete any table 删除任意表行的权限

  delete any view 删除任意视图行的权限

  delete snapshot 删除快照中行的权限

  delete table 为用户删除表行的权限

  delete view 为用户删除视图行的权限

  drop any cluster 删除任意簇的权限

  drop any index 删除任意索引的权限

  drop any procedure 删除任意存储过程的权限

  drop any role 删除任意角色的权限

  drop any sequence 删除任意序列的权限

  drop any snapshot 删除任意快照的权限

  drop any synonym 删除任意同义名的权限

  drop any table 删除任意表的权限

  drop any trigger 删除任意触发器的权限

  drop any view 删除任意视图的权限

  drop profile 删除资源限制简表的权限

  drop public cluster 删除公共簇的权限

  drop public database link 删除公共数据链路的权限

  drop public synonym 删除公共同义名的权限

  drop rollback segment 删除回滚段的权限

  drop tablespace 删除表空间的权限

  drop user 删除用户的权限

  execute any procedure 执行任意存储过程的权限

  execute function 执行存储函数的权限

  execute package 执行存储包的权限

  execute procedure 执行用户存储过程的权限

  force any transaction 管理未提交的任意事务的输出权限

  force transaction 管理未提交的用户事务的输出权限

  grant any privilege 授予任意系统特权的权限

  grant any role 授予任意角色的权限

  index table 给表加索引的权限

  insert any table 向任意表中插入行的权限

  insert snapshot 向快照中插入行的权限

  insert table 向用户表中插入行的权限

  insert view 向用户视图中插行的权限

  lock any table 给任意表加锁的权限

  manager tablespace 管理(备份可用性)表空间的权限

  references table 参考表的权限

  restricted session 创建有限制的数据库会话的权限

  select any sequence 使用任意序列的权限

  select any table 使用任意表的权限

  select snapshot 使用快照的权限

  select sequence 使用用户序列的权限

  select table 使用用户表的权限

  select view 使用视图的权限

  unlimited tablespace 对表空间大小不加限制的权限

  update any table 修改任意表中行的权限

  update snapshot 修改快照中行的权限

  update table 修改用户表中的行的权限

  update view 修改视图中行的权限

-----------------------------------------------------------------------------------

一、权限是用户对一项功能的执行权力。在Oracle中,根据系统管理方式不同,将权限分为系统权限与实体权限两类。系统权限是指是否被授权用户可以连接到数据库上,在数据库中可以进行哪些系统操作。而实体权限是指用户对具体的模式实体(schema)所拥有的权限。这样讲可以有些模糊,举个例子来说:select any table是系统权限,它表示可以查看任何表。而select on table1是实体权限,表示对表table1的查询权限。

二、见上表

三、系统权限授权命令的使用

  语法:

GRANT 权限名 TO 用户|角色|PUBLIC

其中,PUBLIC表示将权限赋给数据库中所有的用户

例:赋给用户USER1权限CREATE TABLE的授权命令如下:

SQL>GRANT CREATE TABLE TO USER1;

授权语句还可以增加WITH ADMIN OPTION选项,表示被授权的用户可以将它所得权限赋给其它用户,如:

SQL>GRANT CREATE TABLE,CREATE VIEW TO USER1,USER2 WITH ADMIN OPTION;

若要了解各用户所拥有的系统权限,可以查询数据字典USER_SYS_PRIVS、ROLE_SYS_PRIVS。

若要回收权限,则使用REVOKE命令,如:

SQL>REVOKE CREATE TABLE FROM USER1;

四、实体权限管理

  实体权限是指某一用户对某一特定schema对象的操作权限。

1.实体权限分类

  不同的实体类型有不同的实体权限,如下表

...........

2.实体权限的授命令

  语法如下:

GRANT 实体权限名|ALL TO 用户|角色|PUBLIC

其中,ALL表示实体的所有实体权限。

如:

SQL>GRANT SELECT ON BOOKS_QUTHORS TO USER1;

以下语句用来查询表的实体权限的授权信息:

SQL>SELECT * FROM USER_TAB_PRIVES

若要回收实体权限,使用REVOKE,其语法如下:

REVOKE 实体权限名|ALL ON 实体名 FROM 用户名|角色名|PUBLIC。

Oracle 查看用户权限

ORACLE中数据字典视图分为3大类,     用前缀区别,分别为:USER,ALL 和 DBA,许多数据字典视图包含相似的信息。

USER_*:有关用户所拥有的对象信息,即用户自己创建的对象信息

ALL_*:有关用户可以访问的对象的信息,即用户自己创建的对象的信息加上其他用户创建的对象但该用户有权访问的信息

DBA_*:有关整个数据库中对象的信息

(这里的*可以为TABLES, INDEXES, OBJECTS, USERS等。

1.查看所有用户:

select * from dba_user;

select * from all_users;

select * from user_users;

2.查看用户系统权限:

select * from dba_sys_privs;

select * from all_sys_privs;

select * from user_sys_privs;

3.查看用户对象权限:

select * from dba_tab_privs;

select * from all_tab_privs;

select * from user_tab_privs;

4.查看所有角色:

select * from dba_roles;

5.查看用户所拥有的角色:

select * from dba_role_privs;

select * from user_role_privs;

6.查看当前用户的缺省表空间

select username,default_tablespace from user_users;

7.查看某个角色的具体权限,如grant connect,resource,create session,create view to TEST;查看RESOURCE具有那些权限,用

SELECT * FROM DBA_SYS_PRIVS WHERE GRANTEE='RESOURCE';
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: