move一个表到另外一个表空间时,索引不会跟着一起move,而且会失效。(LOB类型例外)
表move,我们分为:
*普通表move
*分区表move
*LONG,LOB大字段类型move来进行测试和说明。
索引的move,我们通过rebuild来实现
一:move普通表、索引基本语法:
alter table tab_name move tablespace tbs_name;
move过的普通表,在不用到失效的索引的操作语句中,语句执行正常,但如果操作的语句用到了索引(主键当做唯一索引),则此时报告用到的索引失效,语句执行失败,其他如外键,非空约束,缺省值等不会失效。
我们需要重新创建主键或索引,基本语法为:
1
2
|
alter
index
index_name rebuild;
alter
index
pk_name rebuild;
|
如果我们需要move索引,则使用rebuild语法:
1
2
|
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);如:
1
2
3
|
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);
|
移动表的某个分区:
1
|
ALTER
TABLE
tab_name move
PARTITION partition_name TABLESPACE tbs_name;
|
重建全局索引:
1
2
|
ALTER
INDEX
global_index REBUILD;或
ALTER
INDEX
global_index REBUILD tablespace tbs_name;
|
注: 分区操作时可以带上with update global indexes选项更新全局索引
重建局部索引:
1
|
ALTER
TABLE
tab_name MODIFY
PARTITION partition_name REBUILD UNUSABLE LOCAL
INDEXES;
|
1
|
或
|
1
|
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
LONG不能使用insert into … select …等带select的模式。如
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
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的方法:
1
|
copy from
bigboar/bigboar@bigboar_sid insert
t123(id,en) using select
id,en from
t123;
|
方法二:PL/SQL(如上)
方法三:直接就把LONG转换成CLOB类型
1
2
|
create
table
t321(id int,en clob) tablespace users;
insert
into
t321(id,en) select
id,to_lob(en) from
t123;
|
方法四:exp/imp
1
2
|
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,语法如下如:
1
2
|
alter
table
t321 move
tablespace users;
alter
table
t321 move
lob(en) store as
(tablespace users);
|
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/241379/viewspace-730675/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/241379/viewspace-730675/