【翻译自mos文章】在alter/drop表空间时遇到错误ORA-38301,ORA-00604,purge dba_recyclebin 也不行
2015-02-22 11:56
375 查看
在alter/drop表空间时遇到错误ORA-38301,ORA-00604,purge dba_recyclebin 也不行
适用于:
Oracle Database - Enterprise Edition - Version 10.2.0.1 and later
Information in this document applies to any platform.
症状:
当你试图drop一个empty的tablespace时,遇到与recyclebin相关的错误
尝试purge dba_recyclebin 并 offline该tablespace也不行:
原因:
查询 dba_segments显示该表空间内还有segments
解决方案:
用该schema的owner登陆sqlplus,然后执行purge recyclebin,然后再删除drop tablespace
若是这么还是不解决问题,最快速的变通方法就是disable掉recyclebin,再drop tablespace,再enable recyclbin
---提醒:11gR2里边,recyclebin貌似是静态参数。
若是上面的步骤不能解决问题,请用下面的方法:
适用于:
Oracle Database - Enterprise Edition - Version 10.2.0.1 and later
Information in this document applies to any platform.
症状:
当你试图drop一个empty的tablespace时,遇到与recyclebin相关的错误
SQL> drop tablespace TEST_TBS including contents and datafiles; drop tablespace TEST_TBS including contents and datafiles * ERROR at line 1: ORA-00604: error occurred at recursive SQL level 1 ORA-38301: can not perform DDL/DML over objects in Recycle Bin
尝试purge dba_recyclebin 并 offline该tablespace也不行:
SQL> purge dba_recyclebin;
DBA Recyclebin purged.
SQL> alter tablespace TEST_TBS offline;
Tablespace altered.
SQL> drop tablespace TEST_TBS including contents and datafiles; drop tablespace TEST_TBS including contents and datafiles * ERROR at line 1: ORA-00604: error occurred at recursive SQL level 1 ORA-38301: can not perform DDL/DML over objects in Recycle Bin
原因:
查询 dba_segments显示该表空间内还有segments
SQL> select SEGMENT_NAME,SEGMENT_TYPE,owner from dba_segments where tablespace_name='TEST_TBS'; SEGMENT_NAME SEGMENT_TYPE OWNER ------------------------------ ------------------ ------------------------------ BIN$Pks1AnxmMCTgQ8+Ct10wJA==$0 TABLE ORACLE BIN$Pks790fcQEzgQ8+Ct11ATA==$0 TABLE ORACLE
解决方案:
用该schema的owner登陆sqlplus,然后执行purge recyclebin,然后再删除drop tablespace
SQL> purge recyclebin; SQL> drop tablespace TEST_TBS including contents and datafiles;
若是这么还是不解决问题,最快速的变通方法就是disable掉recyclebin,再drop tablespace,再enable recyclbin
SQL> conn / as sysdba SQL> alter system set recyclebin=off; SQL> drop tablespace TEST_TBS including contents and datafiles; SQL> alter system set recyclebin=on;
---提醒:11gR2里边,recyclebin貌似是静态参数。
若是上面的步骤不能解决问题,请用下面的方法:
1) sqlplus / as sysdba 2) ALTER SYSTEM SET recyclebin = OFF DEFERRED; 3) disconnect and exit sqlplus 4) sqlplus / as sysdba 5) drop tablespace........ 6) sqlplus / as sysdba 7) ALTER SYSTEM SET recyclebin = ON DEFERRED; or ALTER SYSTEM SET recyclebin = ON;
相关文章推荐
- 【翻译自mos文章】使用aum( Automatic Undo Management) 时遇到 ORA-01555错误--- 原因和解决方案。
- 【翻译自mos文章】使用aum( Automatic Undo Management) 时遇到 ORA-01555错误--- 原因和解决方式。
- 【翻译自mos文章】执行utlpwdmg.sql之后报ORA-28003, ORA-20001, ORA-20002, ORA-20003, ORA-20004 错误
- 【翻译自mos文章】在RHEL7或者OL7上安装11.2.0.4时遇到错误 “undefined reference to symbol ‘B_DestroyKeyObject’”
- 【翻译自mos文章】运行utlpwdmg.sql之后报ORA-28003, ORA-20001, ORA-20002, ORA-20003, ORA-20004 错误
- 【翻译自mos文章】在Oracle 12c中建立用户--避免ORA-65096 or ORA-65049错误
- 【翻译自mos文章】Windows平台下的 Oraagent Memory Leak
- 【翻译自mos文章】shutdown normal 挂起 在ora_j00X进程上
- 【翻译自mos文章】rman 备份时报:ORA-02396: exceeded maximum idle time
- 翻译mos文章 磁盘组的错误依赖关系导致数据库启动失败
- ORA-00604: 递归 SQL 级别 1 出现错误 ORA-38301: 无法对回收站中的对象执行 DDL/DML
- 【翻译自mos文章】在Oracle Linux 7上安装11.2.0.4时遇到缺少 pdksh-5.2.14 包
- 【翻译自mos文章】对于JDBC thin client连接,ORA-28040 and SQLNET.ALLOWED_LOGON_VERSION_CLIENT
- 【翻译自mos文章】ORA-19815, Flashback Logs-Space management
- 【翻译自mos文章】/dev/shm应该设置多大Oracle 实例启动时才能不报ORA-00845
- 【翻译自mos文章】 在错误的从os级别remove掉 trace file 之后,怎么找到该trace file的内容?
- 【翻译自mos文章】在11gR2/12c 的GI中,ORA_CRS_HOME 环境变量必须被unset
- 【翻译自mos文章】使用Windows操作系统的Dell Pcserver,Oracle db报错:ORA-8103
- 【翻译自mos文章】rman 备份时报:ORA-02396: exceeded maximum idle time
- 【翻译自mos文章】在11gR2 rac环境中,文件系统使用率紧张,而且lsof显示有非常多oraagent_oracle.l10 (deleted)