繁体   English   中英

如何在Oracle数据库的DBA_SYS_PRIVS表中标识用户帐户

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM