Chinaunix首页 | 论坛 | 博客
  • 博客访问: 542459
  • 博文数量: 128
  • 博客积分: 4000
  • 博客等级: 上校
  • 技术积分: 1345
  • 用 户 组: 普通用户
  • 注册时间: 2008-01-22 21:43
文章分类

全部博文(128)

文章存档

2009年(30)

2008年(98)

我的朋友

分类: Oracle

2008-09-19 16:59:36

今天发现一个用户上有很多特殊的系统权限,才想到是原来导dmp数据时,没有使用grants=n参数,
需要把这些系统权限删除

SQL> select * from dba_sys_privs  p where p.grantee = 'LCMID';

GRANTEE                        PRIVILEGE                                ADM
------------------------------ ---------------------------------------- ---
LCMID                          EXECUTE ANY RULE                         NO
LCMID                          SELECT ANY TABLE                         NO
LCMID                          DEQUEUE ANY QUEUE                        NO
LCMID                          DROP ANY RULE SET                        NO
LCMID                          ENQUEUE ANY QUEUE                        NO
LCMID                          EXECUTE ANY RULE SET                     NO
LCMID                          CREATE SECURITY PROFILE                  NO
LCMID                          DROP ANY SECURITY PROFILE                NO
LCMID                          DROP ANY EVALUATION CONTEXT              NO
LCMID                          EXECUTE ANY EVALUATION CONTEXT           NO

已选择10行。


SQL> revoke execute any rule from lcmid;
revoke execute any rule from lcmid
       *
ERROR 位于第 1 行:
ORA-00990: 缺少或无效权限




SQL> exec dbms_resource_manager_privs.revoke_system_privilege(REVOKEE_NAME => 'LCMID', PRIVILEGE_NAME => 'EXECUTE ANY RULE');
BEGIN dbms_resource_manager_privs.revoke_system_privilege(REVOKEE_NAME => 'LCMID', PRIVILEGE_NAME => 'EXECUTE ANY RULE'); END;

*
ERROR 位于第 1 行:
ORA-29398: 指定的权限名无效
ORA-06512: 在"SYS.DBMS_SYS_ERROR", line 79
ORA-06512: 在"SYS.DBMS_RESOURCE_MANAGER_PRIVS", line 16
ORA-06512: 在"SYS.DBMS_RESOURCE_MANAGER_PRIVS", line 69
ORA-06512: 在line 1

使用TOAD查看,得到如下赋权限的脚本
DBMS_RULE_ADM.GRANT_SYSTEM_PRIVILEGE(
  PRIVILEGE    => SYS.DBMS_RULE_ADM.DROP_ANY_EVALUATION_CONTEXT,
  GRANTEE      => 'LCMID',
  GRANT_OPTION => FALSE);

使用revoke方法:
EXEC DBMS_RULE_ADM.revoke_system_privilege(privilege => sys.dbms_rule_adm.EXECUTE_ANY_RULE,revokee => 'LCMID');

阅读(1409) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~