相信许多朋友在学习oracle数据库的时候对user_、all_、dba_
ORACLE中静态数据字典视图按照前缀的不同通常被分为三类:
1. USER_ 类视图包含了用户所拥有的相关对象信息,用户可以通过这个视图查询自己拥有的对象信息。
2. ALL_ 类视图包含了用户有权限访问的所有对象的信息。
3. DBA_ 类视图包含了数据库所有相关对象的信息,用户需要 SELECT ANY TABLE 权限才能访问。
这三者的关系大致可以用如下示意图描述:
以下为三者的相关内容。
1 、三者的数据字典表
1.1 用户
select * from user_users;
1.2 角色
1.3 权限
分为系统权限与对象权限:
select * from system_privilege_map;(系统)
select * from table_privilege_map;
2 三者之间关系的字典表
这类关系字典表的表名后缀都包含"_privs"
2.1 用户与角色
用户拥有的角色:
select * from dba_role_privs;
select * from user_role_privs;
select * from role_role_privs;
role_role_privs和user_role_privs 都是dba_role_privs的子集.
dba_role_privs的grantee字段包括用户名与角色名.
user_role_privs的username字段包括操作用户的用户名.
role_role_privs的role字段只是角色名.
2.2 用户与权限
用户拥有的系统权限:
select * from dba_sys_privs;
select * from user_sys_privs;
注意: 没有all_sys_privs.
用户拥有的对象权限:
select * from dba_tab_privs;
select * from all_tab_privs;
select * from user_tab_privs;
select * from dba_col_privs;
select * from all_col_privs;
select * from user_col_privs;
2.3 角色与权限
查询授出去的对象权限(通常是属主自己查)
select * from role_sys_privs;
select * from role_tab_privs;
3 其他
查询授出去的对象权限(通常是属主自己查)
select * from user_tab_privs_made;
select * from all_tab_privs_made;
用户拥有的对象权限
select * from user_tab_privs_recd;
select * from all_tab_privs_recd;
用户分配出去的列的对象权限
select * from user_col_privs_made;
select * from all_col_privs_made;
用户拥有的关于列的对象权限
select * from user_col_privs_recd;
select * from all_col_privs_recd;
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/27064835/viewspace-1609221/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/27064835/viewspace-1609221/