错误信息

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

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

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

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

版本

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

原因

这个问题非常简单,就是oracle在删除该用户时发现它还有未断开的会话,因此抛出此错误。注意,即使加cascade参数也无法直接删除还未断开的用户。

解决方法

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

1、排查

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

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

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

2、解决

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

alter system kill session '36,7';

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

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

drop user test1 cascade;