当前位置: 首页
数据库
Oracle如何撤销用户的DBA权限_执行REVOKE DBA操作

Oracle如何撤销用户的DBA权限_执行REVOKE DBA操作

热心网友 时间:2026-04-29
转载

Oracle如何撤销用户的DBA权限_执行REVOKE DBA操作

想收回一个用户的DBA权限,可不是简单地在图形界面上点掉勾选就万事大吉了。这里面有几个关键步骤和容易踩的坑,操作不当,用户可能依然拥有部分高危权限。核心操作是:必须用 SYS AS SYSDBA 或带 ADMIN OPTION 的 DBA 用户执行 REVOKE DBA FROM scott;,且需在对应容器(CDB/PDB)中操作,并验证是否残留 CREATE SESSION 等权限。

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

Oracle如何撤销用户的DBA权限_执行REVOKE DBA操作

具体来说,你必须使用具有 dba 权限的用户(比如 syssystem)来执行 revoke dba from user_name; 命令。否则,系统会毫不客气地抛出一个 ora-01031: insufficient privileges 错误,告诉你权限不足。

用哪个账号执行 REVOKE DBA 才有效

这里有个硬性规定:只有本身拥有 DBA 角色且附带 ADMIN OPTION 选项的用户,才有资格撤销其他用户的 DBA 权限。通常,SYS AS SYSDBASYSTEM 用户是可行的选择,但前提是后者的 ADMIN OPTION 没有被手动移除。稳妥起见,最可靠的方式还是用 SYS 登录:

sqlplus / as sysdba

登录成功后,直接运行撤销命令:

REVOKE DBA FROM scott;

注意两个细节:第一,用户名 scott 必须大写(除非创建时用了双引号指定小写);第二,确保该用户当前确实拥有 DBA 角色。否则,你会收到 ORA-01952: system privilege not granted to 'SCOTT' 的提示。

REVOKE DBA 不能跨实例或跨容器生效

在Oracle的多租户(CDB/PDB)环境下,这一点尤其需要注意。DBA 是一个数据库级别的角色,而不是CDB级别的全局角色。这意味着,如果你在CDB$ROOT(根容器)中执行 REVOKE DBA FROM scott;,这个操作只对根容器生效。如果 scott 用户在某个特定的PDB(可插拔数据库)里也被授予了 DBA 角色,那么PDB中的权限并不会自动消失。

怎么处理?按这个步骤来:

  • 先定位:查询 SELECT CON_ID, GRANTEE, GRANTED_ROLE FROM CDB_ROLE_PRIVS WHERE GRANTEE = 'SCOTT' AND GRANTED_ROLE = 'DBA';,确认用户在哪个容器拥有权限。
  • 再切换:根据查询到的 CON_ID,切换到对应的容器连接(例如:ALTER SESSION SET CONTAINER = pdb1;)。
  • 后执行:在正确的容器中再次执行 REVOKE 命令。

顺便提一句,别太依赖PL/SQL Developer这类图形化工具的“去掉勾选”操作。界面操作可能只针对你当前连接的容器,一不小心就会遗漏。

撤销后用户仍能连库?检查 CREATE SESSION 是否残留

这是一个常见的“后遗症”。DBA 角色确实包含 CREATE SESSION 权限,但撤销 DBA 角色并不会自动收回这个单独的权限。用户可能之前被单独授予过 CREATE SESSION,或者属于 CONNECT 角色(在旧版本中默认包含此权限)。

所以,执行完 REVOKE DBA FROM scott; 后,强烈建议顺手检查一下:

SELECT * FROM DBA_SYS_PRIVS WHERE GRANTEE = 'SCOTT' AND PRIVILEGE = 'CREATE SESSION';

如果查询结果非空,而你的目的是彻底禁止该用户登录,那么就需要额外执行:

REVOKE CREATE SESSION FROM scott;

否则,用户 scott 仍然可以连接到数据库,只是无法执行 DROP USERALTER SYSTEM 这类高危操作了。

图形化工具里点“删掉 DBA 角色”为什么有时不生效

PL/SQL Developer、SQL Developer 这些工具的图形界面,本质上也是在后台拼接SQL语句执行。但它们有时会漏掉几个关键点:

  • 容器上下文不明确:尤其在PDB中操作时,工具可能默认连接到CDB$ROOT,而没有显式指定 CONTAINER = CURRENT
  • 事务未提交:点击“Apply”后,有些版本需要手动按Ctrl+Enter或在确认弹窗中提交,事务才算真正完成。
  • 大小写敏感问题:更隐蔽的情况是,界面上显示的是小写的 dba,但数据库元数据中存储的是大写的 DBA。图形界面的删除逻辑可能因为大小写匹配失败而导致操作无效。

遇到图形界面操作无效的情况,最直接的办法就是回到命令行。用 sqlplus / as sysdba 直接执行语句,然后查询 DBA_ROLE_PRIVS 视图来确认操作结果。

说到底,撤销DBA权限的难点,并不在于执行那条 REVOKE 命令本身,而在于搞清楚用户位于哪个容器、是否还有残留的系统权限、以及图形化工具背后有没有“悄悄”绕过你的意图。记住,不要完全相信界面上的“已应用”提示,务必通过查询数据字典视图来进行最终验证。

来源:https://www.php.cn/faq/2385656.html

游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

同类文章
更多
Oracle分区表物化视图如何支持高并发_优化锁资源竞争

Oracle分区表物化视图如何支持高并发_优化锁资源竞争

Oracle物化视图FAST REFRESH默认锁整分区表,因物化视图日志缺失分区键信息,无法定位变更分区;需同时满足日志含分区键列且MV定义显式引用该列,才能实现分区粒度加锁。 物化视图刷新时为什么会锁定整个分区表? 许多Oracle DBA都曾面临一个典型问题:在执行分区表的物化视图FAST R

时间:2026-04-29 19:49
如何处理SQL语句中的HEX编码注入绕过_对输入流进行16进制检测

如何处理SQL语句中的HEX编码注入绕过_对输入流进行16进制检测

HEX编码绕过:当十六进制字面量成为SQL注入的“隐身衣” 在安全对抗的战场上,攻击者的手法总是层出不穷。其中,利用十六进制(HEX)编码绕过传统的关键字和符号过滤,已经成为一种相当经典且有效的SQL注入手段。这背后的原理并不复杂,但防御起来却需要格外细致的考量。 HEX编码在SQL注入中怎么被用来

时间:2026-04-29 19:49
Oracle RMAN备份加密如何配置_通过配置备份加密增强安全性

Oracle RMAN备份加密如何配置_通过配置备份加密增强安全性

RMAN备份加密:那些容易被忽略的配置陷阱与性能真相 说到RMAN备份加密,一个常见的误解是“配置了就能自动生效”。事实并非如此,关键在于必须清晰区分configure encryption for database on(全局策略)和set encryption on identified by(

时间:2026-04-29 19:48
SQL怎样实现类似Excel透视表的功能_利用CASE WHEN行转列

SQL怎样实现类似Excel透视表的功能_利用CASE WHEN行转列

SQL怎样实现类似Excel透视表的功能_利用CASE WHEN行转列 SQL里用CASE WHEN做行转列,本质是聚合+条件判断 开门见山,先说核心:CASE WHEN这个语句本身并不产生“转列”的魔法。它必须和GROUP BY以及聚合函数(比如SUM、COUNT)联手,才能模拟出Excel透视表

时间:2026-04-29 19:48
如何解决ORA-12541无监听程序_lsnrctl status排查流程

如何解决ORA-12541无监听程序_lsnrctl status排查流程

ORA-12541 连接失败深度解析:监听器未启动是主因,系统化排查从状态检查到网络验证 ORA-12541 报错时,先确认监听器进程是否真的在运行 当数据库连接出现 ORA-12541 错误时,许多用户会首先怀疑 tnsnames ora 配置或服务名设置。实际上,该错误的根本原因在于客户端无法与

时间:2026-04-29 19:48
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程