1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > Oracle数据库删除用户和删除表空间及常见错误解决

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

时间:2019-07-16 10:25:54

相关推荐

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

最近工作用到了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结束,就可以删除表空间了

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。