Oracle数据库删除用户和删除表空间及常见错误解决

最近工作用到了impdp命令(数据库导入),与它对应的是expdp(工作中遇到了,在给大家讲讲遇到的问题),在删除用户和表空间时,遇到了点问题,写一下解决办法,供大家参考。

首先讲下删除用户和表空间

1、在Linux系统用sqlplus登录

1、切换到oracle用户
    su - oracle
2、登录sys用户
    sqlplus / as sysdba

2、查找用户

select * from dba_user;

3、删除用户

drop user 用户名 cascade;
例如:
drop user hbnxnc cascade;

4、删除表空间

4.1、删除空的表空间,但是不包含物理文件

	drop tablespace tablespace_name;

4.2、删除非空表空间,包含物理文件

drop tablespace tablespace_name including contents;

4.3、删除空表空间,包含物理文件

drop tablespace tablespace_name including datafiles; 

4.4、删除非空表空间,包含物理文件

drop tablespace tablespace_name including contents and datafiles;

4.5、如果其他表空间中的表有外键等约束关联到了本表空间中的表的字段,就要加上CASCADE CONSTRAINTS

drop tablespace tablespace_name including contents and datafiles CASCADE CONSTRAINTS;

接下来讲下遇到的问题,重点!!

一、在删除用户的时候,会遇到下面的一个错误:

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

SQL> drop user hbnxnc;
ERROR at line 1:
ORA-01940: cannot drop a user that is currently connected
造成这个问题的原因是很明显的,有用户在连接,不允许drop掉该user。

        解决方案:

             首先查找这个用户有没有在使用

select username,sid,serial#,PROGRAM from v$session where username='HBNXNC';
--用户名必须大写
	USERNAME                                    SID    SERIAL# 
	------------------------------ ---------- ---------------------------------------------
	hbnxnc                                       634        7   

            其次是杀死系统中的会话进程      

alter system kill session '634,7';
--批量杀死会话进程
SELECT 'ALTER SYSTEM kill SESSION '''  ||SID||','||SERIAL#||''' IMMEDIATE;' FROM V$SESSION where username='HBNXNC';
--使用ALTER SYSTEM KILL SESSION 'sid,serial#' IMMEDIATE 来快速回滚事物、释放会话的相关锁、立即---返回当前会话的控制权。

一般情况下,执行完这些,在执行drop user就可以把用户删掉了。但是,有时候刚删掉所有会话进程,又有新的进程出现了,怎么kill也不行,用户删不掉,下面说下解决办法(重中之重!!

方式一:

1、停止Oracle数据库的监听程序

lnsrctl stop

2、执行上面杀死会话进程的方法

3、执行drop user 语句

方式二:

有时候,你会发现数据库用的是grid创建的监听,没有grid用户,监听停不掉,需要用到了下面的方法

1、用sqlplus登录oracle数据库,将要删除的用户锁定

alter user sysdb account lock;

2、用户锁定后,执行删除会话进程的语句,就可以了

alter system kill session 'SID,SERIAL#';

3、执行drop user语句

二、在删除表空间遇到的错误

           ORA-00604和ORA-00054

查看进程

SELECT  *  FROM dba_datapump_jobs

图片上有个state,对应的是EXECUTING,将这样的JOB_NAME用kill杀掉

2、在Linux用SSH登录所操作数据库,执行下面这句话

impdp hbnxnc1/123456@10.5.140.112/ncdb attach=SYS_IMPORT_FULL_01

出现import后,在import后面,输入kill,等待kill结束,就可以删除表空间了

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值