侧边栏壁纸
博主头像
与晚风述往事博主等级

万般皆下品,唯有读书高。

  • 累计撰写 149 篇文章
  • 累计创建 29 个标签
  • 累计收到 7 条评论

目 录CONTENT

文章目录

Oracle ORA-01940:无法删除当前已连接的用户

与晚风述往事
2021-10-10 / 1 评论 / 0 点赞 / 1,593 阅读 / 400 字 / 正在检测是否收录...
温馨提示:
本文最后更新于 2021-10-20,若内容或图片失效,请留言反馈。部分素材来自网络,若不小心影响到您的利益,请联系我们删除。

错误信息

【汉】ORA-01940:无法删除当前已连接的用户

【英】ORA-01940:cannot drop a user that is currently connected

在正常运行的实例中删除用户时报错。
oracle_ora_01940_1

版本

在所有版本中都可能会遇到。

这个问题非常简单,就是oracle在删除该用户时发现它还有未断开的会话,因此抛出此错误。

解决报错的方法也非常简单,就是找到连接的会话,然后杀掉它,再重新删除用户就可以了。

1、排查

排查主要是为了查到连接会话的SID和SERIAL#,因为杀会话需要这两个标识符。

select * from v$session where username='TEST1';
oracle_ora_01940_2

2、解决

得到会话的SID和SERIAL#后,就可以使用语句来杀掉连接的会话。

alter system kill session '36,7';

杀掉会话后,可以继续删除用户,这次就不会再报错了。

drop user test1 cascade;
oracle_ora_01940_3

0

评论区