![](/img/trans.png)
[英]How to determine what privileges a user has when the username is not present in the DBA_TAB_PRIVS table?
[英]How to identify user account in DBA_SYS_PRIVS table in Oracle Database
我正在尝试在DBA_SYS_PRIVS表中查找具有某些特权的所有用户。 该表具有GRANTEE列,并且根据Oracle官方网站,GRANTEE列显示“接受授予的被授予者姓名,用户或角色”。 那么我怎么知道GRANTEE是帐户还是角色? 例如,在Oracle DB中有一个名为SYS的角色,还有一个名为SYS的帐户。 那么我怎么知道这是一个帐户还是角色????
同样在表DBA_TAB_PRIVS中,有一列称为GRANTEE。 在此表中,GRANTEE列是“授予访问权限的用户名”。 所以我很困惑,因为“ GRANTEE”列在两个不同的表中表示不同的东西
请帮忙,谢谢ssssssssssss
在Oracle中没有SYS
角色。
SQL> select * from dba_roles where role='SYS';
no rows selected
实际上,您无法创建与用户名相同名称的角色。
SQL> create role sys;
create role sys
*
ERROR at line 1:
ORA-01921: role name 'SYS' conflicts with another user or role name
仅获取不带用户名的角色。
SQL>select grantee from dba_sys_privs where grantee not in(select username from all_users);
仅获取没有角色的用户。
SQL>select grantee from dba_sys_privs where grantee in(select username from all_users)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.