加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Oracle Move Tablespace

发布时间:2020-12-12 13:34:37 所属栏目:百科 来源:网络整理
导读:move一个表到另外一个表空间时,索引不会跟着一起move,而且会失效。(LOB类型例外) ?move分为: *普通表move *分区表move *LONG,LOB大字段类型move来进行测试和说明。 ?索引的move,我们通过rebuild来实现。 一:move普通表、索引基本语法: alter table ta

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;

注: 分区操作时可以带上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_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的模式。如

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/[email?protected]_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);

?

?转自:https://www.cnblogs.com/Cratical/archive/2010/08/24/1806948.html

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

move一个表到另外一个表空间时,索引不会跟着一起move,而且会失效。(LOB类型例外)

?move分为:

*普通表move

*分区表move

*LONG,LOB大字段类型move来进行测试和说明。

?索引的move,我们通过rebuild来实现。

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

alter table tab_name move tablespace tbs_name;

move过的普通表,在不用到失效的索引的操作语句中,语句执行正常,但如果操作的语句用到了索引(主键当做唯一索引),则此时报告用到的索引失效,语句执行失败,其他如外键,非空约束,缺省值等不会失效。

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

    推荐文章
      热点阅读