Move表、索引、LOB / Long [ zt ] 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 - 64 bit ProductionPL / SQL Release 9.2 . 0.6 . 0 - ProductionCORE 9.2 . 0.6 . 0 ProductionTNS for Solaris: Version 9.2 . 0.6 . 0 - ProductionNLSRTL 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; [ xsb注: 分区操作时可以带上with update global indexes选项更新全局索引。 ] 重建局部索引: ================ 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_TABLESUSER_IND_PARTITIONSUSER_IND_SUBPARTITIONSUSER_LOB_PARTITIONSUSER_LOB_SUBPARTITIONSUSER_PART_INDEXESUSER_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 = t123imp 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);