失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > Oracle表空间删除报错问题的解决

Oracle表空间删除报错问题的解决

时间:2019-03-23 05:14:10

相关推荐

Oracle表空间删除报错问题的解决



报错有下面几种:

一. ORA-23515

--- ORA-23515: materialized views and/or their indices exist in the tablespace

drop tablespace crm_data including contents and datafiles

*

ERROR at line 1:

ORA-23515: materialized views and/or their indices exist in the tablespace

意思是:该表空间 CRM_DATA含有物化视图,或者含有物化视图的索引

解决办法:

-- 首先删掉该表空间下的的物化视图

select 'drop materialized view '||owner||'.'||segment_name||' ;'

from dba_segments

where segment_name in (select mview_name from dba_mviews)

and tablespace_name = 'CRM_DATA'

-- 然后删除该表空间下的其他表空间下物化视图在本表空间下创建的索引

select *

from dba_segments

where tablespace_name = 'CRM_DATA'

and segment_name in

(select index_name

from dba_indexes

where table_name in (select mview_name from dba_mviews));

二. ORA-02429

---ORA-02429: cannot drop index used for enforcement of unique/primary key

drop tablespace crm_idx including contents cascade constraints

*

ERROR at line 1:

ORA-00604: error occurred at recursive SQL level 1

ORA-02429: cannot drop index used for enforcement of unique/primary key

ORA-02429的意思是: 让你删除该表空间下面的 primary key 和 unique key

处理办法:

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 = 'CRM_IDX');

三. ORA-14404

--ORA-14404: partitioned table contains partitions in a different tablespace

drop tablespace crm_arc_data including contents and datafiles

*

ERROR at line 1:

ORA-14404: partitioned table contains partitions in a different tablespace

意思是: 本表空间下面有这么样一个或一些分区表的分区: this partition OR partitions的table所包含的全部 partitions不在一个表空间下面:

处理办法:

select 'alter table '||owner||'.'||segment_name||' drop partition '||partition_name||' ;'

from dba_segments

where segment_name in (select distinct segment_name

from dba_segments

where tablespace_name = 'CRM_ARC_DATA'

and segment_type like '%PART%')

and tablespace_name <> 'CRM_ARC_DATA';

杀手锏: 直接drop 这个分区表(如果允许的话)

四. ORA-02449

--- ORA-02449: unique/primary keys in table referenced by foreign keys

drop tablespace crm_data including contents and datafiles

*

ERROR at line 1:

ORA-02449: unique/primary keys in table referenced by foreign keys

意思是: 这个要删除的表空间 里面含有这么样的一些主键: 其他表空间的表在这些主键上建有外键

处理办法: 去掉这些垃圾外键

select 'alter table '||owner||'.'||table_name||' drop constraint '||constraint_name||' ;'

from dba_constraints

where constraint_type = 'R'

and table_name in (select segment_name

from dba_segments

where tablespace_name = 'CRM_DATA'

and segment_type like '%TABLE%');

如果还是不行的话,就用这个语句来删表空间吧:

drop tablespace crm_data including contents cascade constraints

如果觉得《Oracle表空间删除报错问题的解决》对你有帮助,请点赞、收藏,并留下你的观点哦!

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