当前位置: 代码迷 >> 综合 >> oracle 删除表空间错误 提示:ORA-02429
  详细解决方案

oracle 删除表空间错误 提示:ORA-02429

热度:81   发布时间:2024-03-08 10:13:44.0

sql>drop tablespace OFBIZ;
ora-01549:表空间非空,请使用INCLUDING CONTENTS 选项
sql>drop tablespace OFBIZ INCLUDING CONTENTS and datafiles;
ora-00604:递归sql层1出现错误。
ora-02429:无法删除用于强制唯一/主键的索引。
sql>drop tablespace OFBIZ including contents cascade constraints;
ora-00604:递归sql层1出现错误。
ora-02429:无法删除用于强制唯一/主键的索引。
sql>select segment_name,partition_name,tablespace_name from   dba_extents    where tablespace_name=upper('OFBIZ');

显示出2个表的主键的表空间是:'zfxfzb'.
sql>select 'alter table '||owner||'.'||table_name||' drop constraint '||constraint_name||' ;'
from dba_constraints
where constraint_type in ('U', 'P')
   and (index_owner, index_name) in
       (select owner, segment_name
          from dba_segments
         where tablespace_name = upper('OFBIZ'));

显示结果如下:
alter table TEST.SYS_CODE drop constraint PK_CODEID ;
alter table TEST.KS_WPYP_PWPLGX drop constraint PK_KS_WPYP_PWPLGX ;
执行以上2条显示的结果
sql>alter table TEST.SYS_CODE drop constraint PK_CODEID ;
表已经更改
sql>alter table TEST.KS_WPYP_PWPLGX drop constraint PK_KS_WPYP_PWPLGX ;
表已经更改
sql>drop tablespace OFBIZ INCLUDING CONTENTS and datafiles

  相关解决方案