移动分区表++oracle,ORACLE表和索引的移动(非/分区)

本文详细介绍了如何在Oracle数据库中移动表和索引到新的表空间,包括普通表、分区表以及LONG和LOB类型的字段。在移动过程中,索引会失效,需要重建。对于LONG类型数据,建议避免使用或采用其他方式迁移,而对于LOB类型,需要额外处理其存储和索引。整个过程涉及ALTER TABLE命令和重建索引的操作,以及查询相关视图以获取表和索引信息。
摘要由CSDN通过智能技术生成

问题描述:

一个表空间太大,删除数据后由于文件尾被用,无法resize,打算把所有表空间上的对象move到一个临时存储

的表空间做整理。

(本文非原创,来自C博客) move一个表到另外一个表空间时,索引不会跟着一起move,而且会失效。(LOB类型例外)表move,我们分为:

*普通表move

*分区表move

*LONG,LOB大字段类型move

下面来进行测试和说明。索引的move,我们通过rebuild来实现

SQL> select * from v$version;

Oracle9i Enterprise Edition Release 9.2.0.6.0 - 64bit

Production

PL/SQL Release 9.2.0.6.0 - Production

CORE 9.2.0.6.0 Production

TNS for Solaris: Version 9.2.0.6.0 - Production

NLSRTL Version 9.2.0.6.0 - Production

一:move普通表、索引基本语法:

alter table tab_name move tablespace tbs_name;

move过的普通表,在不用到失效的索引的操作语句中,语句执行正常,但如果操作的语句用到了索引(主键当做

唯一索引),则此时报告用到

的索引失效,语句执行失败,其他如外键,非空约束,缺省值等不会失效。

我们需要重新创建主键或索引,基本语法为:

alter index index_name rebuild;

alter index pk_name rebuild;

如果我们需要move索引,则使用rebuild语法:

alter index index_name rebuild tablespace tbs_name;

alter index pk_name rebuild tablespace tbs_name;

提示:查询表所具有的索引,可以使用user_indexes视图(索引和主键都在这个视图里可找到)。

二:move分区表及索引和普通表一样,索引会失效,区别的仅仅是语法而已。

分区基本语法:特别提醒注意,如果是单级分区,则使用关键字PARTITION,如果是多级分区,则使用

SUBPARTITION替代PARTITION。如果分区或分区索引比较大,可以使用并行move或rebuild,PARALLEL

(DEGREE

2);如:

ALTER TABLE PART_ALARMTEXTDATA move SUBPARTITION

ALARMTEXTDATA_050910_ATD01 TABLESPACE users

PARALLEL (DEGREE 2);

ALTER INDEX GLOBAL_ALARMTEXTDATA REBUILD tablespace users PARALLEL

(DEGREE 2);

ALTER INDEX LOCAL_ALARMTEXTDATA REBUILD SUBPARTITION

ALARMTEXTDATA_050910_ATD01 TABLESPACE users

PARALLEL (DEGREE 2);

移动表的某个分区:

================

ALTER TABLE tab_name move PARTITION partition_name TABLESPACE

tbs_name;

重建全局索引:

================

ALTER INDEX global_index REBUILD;或

ALTER INDEX global_index REBUILD tablespace tbs_name;

重建局部索引:

================

ALTER TABLE tab_name MODIFY PARTITION partition_name REBUILD

UNUSABLE LOCAL INDEXES;或

ALTER INDEX local_index_name REBUILD PARTITION partition_name

TABLESPACE tbs_name;

提示:

USER_PART_TABLES

USER_IND_PARTITIONS

USER_IND_SUBPARTITIONS

USER_LOB_PARTITIONS

USER_LOB_SUBPARTITIONS

USER_PART_INDEXES

USER_PART_LOBS可查询分区相关内容,同时,分区对象,也是segment,所以也可在dba_segments里查的到。

三:move LONG,LOB类型据说DBMS_REDEFINITION包可以提供一些方便,没用过。

I:LONG类型

long类型不能通过MOVE来传输特别提示,尽量不要用LONG类型,特难管理。参考:

http://www.anysql.net/2005/12/long_vs_lob.html

1,LONG不能使用insert into ... select ...等带select的模式。如

create table t123 (id int,en long);则

insert into t123(id,en) select * from

t123;报告错误,可以用pl/sql来帮助解决,如:

declare

cursor cur_t123 is select * from t123;

use_t123 cur_t123%rowtype;

begin

open cur_t123;

loop

fetch cur_t123 into use_t123;

exit when cur_t123%notfound;

insert into t123(id,en) values (use_t123.id,use_t123.en);

end loop;

close cur_t123;

end;

/

对有LONG类型字段的表的转移,可以使用:

create新表的方法。

* create一个新的表,存储在需要转移的表空间。

* 创建新的索引(使用tablespace 子句指定新的表空间)。

* 把数据转移过来

方法一:用COPY的方法:

copy from bigboar/bigboar@bigboar_sid

insert t123(id,en) using select id,en from t123;

方法二:PL/SQL(如上)

方法三:直接就把LONG转换成CLOB类型

create table t321(id int,en clob) tablespace users;

insert into t321(id,en) select id,to_lob(en) from t123;

方法四:exp/imp

exp bigboar/bigboar file=a.dat tables=t123

imp bigboar/bigboar file=a.dat full=y IGNORE =y

* drop掉旧表。

* rename 新表为旧表表名。

II:LOB类型在建立含有lob字段的表时,oracle会自动为lob字段建立两个单独的segment,一个用来存放数据

(segment_type=LOBSEGMENT),另一个用来存放索引(segment_type=LOBINDEX)。默认它们会存储在和表一起

的表空间。我们对表MOVE时,LOG类型字段和该字段的索引不会跟着MOVE,必须要单独来进行MOVE,语法如下如

alter table t321 move tablespace users;

alter table t321 move lob(en) store as (tablespace

users);

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值