74、move 操作

本文介绍了Oracle数据库中表和索引的迁移方法,包括普通表、分区表、LONG和LOB类型字段的处理方式。详细解释了不同类型的表在迁移过程中索引的状态变化及其重建方法。
 

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

表move,我们分为:
*普通表move
*分区表move
*LONG,LOB大字段类型move来进行测试和说明。

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


一: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_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);

ref:移动LOB字段至新表空间

任务描述 本关任务:在一座城池中有N个谷仓,每个谷仓分别有Ni​袋粮食并堆成了一列,重量分别为Wj​,为了应对外敌,通常需要在谷仓间调动粮食,每次调动只会选择粮堆最上面的一袋粮食运走,并放在目的谷仓粮堆的最上面。 相关知识 为了完成本关任务,你需要掌握:1.向量的相关操作,2.嵌套使用向量模拟二维动态数组。 向量的相关操作 粮食调动是在粮堆的最上面进行的操作,涉及的向量操作为push_back和pop_back,详细的向量具体操作和运用请参考STL模板之动态数组:向量vector的操作。 嵌套使用向量模拟二维动态数组 谷仓的数量在不同的测试用例下是不同的,每个谷仓中的粮食袋数是动态变化的,因此,可以使用二维的动态数组来求解,既方便又节约内存。 第一步:定义一个以粮食重量int为数据类型的动态数组vector<int>; 第二步:定义一个以粮食重量向量vector<int>为数据类型的动态数组vector<vector<int> > vec。 这样,vec的第一维下标就表示谷仓的ID,第二维就是对应谷仓的各袋粮食的重量。 编程要求 本关的编程任务是补全右侧代码片段main中Begin至End中间的代码,具体要求如下: 创建一个vector<vector<int> > vec二维动态向量,读取各个谷仓的初始粮食状况; 基于向量的push_pack和pop_back等基本操作,实现M次调动粮食; 输出最后各个谷仓ID、该谷仓中各袋粮食的重量以及总的重量(请严格遵循测试样例的输出格式)。 测试说明 平台将自动编译补全后的代码,并生成若干组测试数据,接着根据程序的输出判断程序是否正确。 以下是平台的测试样例: 测试输入: 5 3 79 32 29 4 42 41 92 6 6 68 37 63 11 34 79 2 63 36 3 27 74 67 6 move 1 2 move 3 0 move 3 0 move 4 2 move 1 4 move 2 0 预期输出: 0 79 32 29 36 63 67 306 1 42 41 83 2 68 37 63 11 34 79 6 298 3 0 0 4 27 74 92 193 输入格式: 第一行整数N:谷仓数量 接下来N行,依次为各个谷仓ID=[0,1,...,N−1]的初始信息:第一个数字为该谷仓的初始粮食袋数Ni​,后面接着Ni​袋粮食的重量Wj​ 接下来一行整数M:调动粮食次数 接下来M行,每行move a b:将谷仓a粮堆的最后一袋粮食调动到谷仓b粮堆的最上面 输出格式: 输出N行,按顺序输出谷仓ID=[0,1,...,N−1]的最终状态信息:ID W0​ W1​ ... Wj​ Wsum​,若谷仓空了,则输出为ID 0 0 注意:每行所有数字中间空格隔开,末尾换行\n
06-13
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值