exchange partition

在线重定义表可以将一个非分区表转换成一个分区表。使用exchange 和split partition 也可以将一个非分区表转换为分区表。后者相比较前者,因为不受要转换的数据量影响,因此也更方便、快捷一些。

     exchange partition 操作能将一个分区表的一个分区和另一张表的数据互换,这里的互换是segment 头部信息的修改,数据block 并不做改动,因此,和数据量无关,速度会非常快;完成后,再可以按照需要将分区具体split 成多个分区。

步骤:
1.建立一个空的,只有一个分区的同构分区表
2.exchange partition with table 来互换数据
3.split 分区表的分区为合适的个数

-- 建立非分区表
create table test_objects as select * from user_objects;

-- 建立空的分区表
create table test_part_objects
partition by range(object_id)
(partition max_data values less than (maxvalue))
as select * from test_objects where 1=2; 

select count(*) from test_objects;
1579
select count(*) from test_part_objects;
0

-- 执行exchange partition操作
alter table test_part_objects exchange partition max_data with table test_objects;

--分区表中有数据了,原表没有了数据
select count(*) from test_objects;
0
select count(*) from test_part_objects;
1579
select count(*) from test_part_objects partition(max_data);
1579

--split分拆分区
alter table test_part_objects split partition max_data
at (54000) into (partition part_54000,partition max_data);

select count(*) from test_part_objects partition(max_data);
172

-- 再次执行exchange partition,将max_data分区中的数据交换到test_objects表
alter table test_part_objects exchange partition max_data with table test_objects;

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/17012874/viewspace-697412/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/17012874/viewspace-697412/

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值