oracle删除用户出现ora01940,ORA-01940 无法删除当前已连接的用户之解决方案

当尝试在Oracle数据库中执行dropuser命令时,如果用户当前处于连接状态,会遇到ORA-01940错误。为了解决此问题,需要首先查询并确定哪个进程正在使用该用户,然后通过alter system kill session命令终止相关进程。之后,可以成功删除用户。本文详细介绍了这一过程。
摘要由CSDN通过智能技术生成

在执行drop user的时候,提示报错信息:ORA-01940: cannot drop a user that is currently connected

SQL> drop user ecity ;

ERROR at line 1:

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

造成这个问题的原因是很明显的,有用户在连接,不允许drop掉该user。

解决方案:

首先查询一下数据中有没有用户在使用

select username,sid,serial#,paddr from v$session where username='ECITY';

USERNAME SID SERIAL# PADDR

------------------------------ ---------- -------------------------------------------------

ECITY 634 7 00000000C028D198

SQL> select PROGRAM from v$process where addr='00000000C028D198';

PROGRAM

----------------------------------------------------------------------------------------------------------

Oracle@oradb01 (DW00)

其次杀掉系统中的这个进程

SQL> alter system kill session '634,7';

System altered.

然后执行删除操作,即可完成

SQL> select saddr,sid,serial#,paddr,username,status from v$session where username is not null;

SQL> drop user ecity CASCADE;

User dropped.

注:本文转自https://www.cnblogs.com/lwlxqlccc/p/8694696.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值