最近工作用到了impdp命令(数据库导入),与它对应的是expdp(工作中遇到了,在给大家讲讲遇到的问题),在删除用户和表空间时,遇到了点问题,写一下解决办法,供大家参考。
首先讲下删除用户和表空间
1、在Linux系统用sqlplus登录
1、切换到oracle用户su - oracle2、登录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';--用户名必须大写USERNAMESID 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 来快速回滚事物、释放会话的相关锁、立即---返回当前会话的控制权。
一般情况下,执行完这些,在执行dropuser就可以把用户删掉了。但是,有时候刚删掉所有会话进程,又有新的进程出现了,怎么kill也不行,用户删不掉,下面说下解决办法(重中之重!!)
方式一:
1、停止Oracle数据库的监听程序
lnsrctl stop
2、执行上面杀死会话进程的方法
3、执行dropuser语句
方式二:
有时候,你会发现数据库用的是grid创建的监听,没有grid用户,监听停不掉,需要用到了下面的方法
1、用sqlplus登录oracle数据库,将要删除的用户锁定
alter user sysdb account lock;
2、用户锁定后,执行删除会话进程的语句,就可以了
alter system kill session 'SID,SERIAL#';
3、执行dropuser语句
二、在删除表空间遇到的错误
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结束,就可以删除表空间了