--0.重建分区表
SQL> drop table testrp;
SQL> drop table testrp;
表已丢弃。
SQL> create table testrp(a number(10), b varchar2(10))
2 partition by range(a)(
3 partition testrp1 values less than (51),
4 partition testrp2 values less than (81)
5 )
6 tablespace tp_p1;
2 partition by range(a)(
3 partition testrp1 values less than (51),
4 partition testrp2 values less than (81)
5 )
6 tablespace tp_p1;
表已创建。
--1.插入正常范围的数据
SQL> insert into testrp values(1,'1');
已创建 1 行。
SQL> insert into testrp values(50,'50');
已创建 1 行。
SQL> insert into testrp values(51,'51');
已创建 1 行。
SQL> insert into testrp values(80,'80');
已创建 1 行。
SQL> commit;
提交完成。
--2.插入异常范围的数据
SQL> insert into testrp values(81,'81');
insert into testrp values(81,'81')
*
ERROR 位于第 1 行:
ORA-14400: 插入的分区关键字未映射到任何分区
insert into testrp values(81,'81')
*
ERROR 位于第 1 行:
ORA-14400: 插入的分区关键字未映射到任何分区
SQL> insert into testrp values(null,null);
insert into testrp values(null,null)
*
ERROR 位于第 1 行:
ORA-14400: 插入的分区关键字未映射到任何分区
--3.增加一个maxvalue分区,null值插入到了该分区
SQL> alter table testrp add partition testrp3 values less than (maxvalue) tablespace tp_p3;
SQL> alter table testrp add partition testrp3 values less than (maxvalue) tablespace tp_p3;
表已更改。
SQL> insert into testrp values(81,'81');
已创建 1 行。
SQL> commit;
提交完成。
SQL> insert into testrp values(null,null);
已创建 1 行。
SQL> commit;
提交完成。
--4.可以查询总数据和指定分区的数据(查询时指定分区,能大大提高查询效率)
SQL> select * from testrp;
A B
---------- ----------
1 1
50 50
51 51
80 80
81 81
---------- ----------
1 1
50 50
51 51
80 80
81 81
已选择6行。
SQL> select * from testrp partition(testrp1);
A B
---------- ----------
1 1
50 50
---------- ----------
1 1
50 50
SQL> select * from testrp partition(testrp2);
A B
---------- ----------
51 51
80 80
---------- ----------
51 51
80 80
SQL> select * from testrp partition(testrp3);
A B
---------- ----------
81 81
---------- ----------
81 81
--5.更新操作也可指定分区,能提高查询效率。
SQL> update testrp partition(testrp1) set a = 11 where a is null;
已更新0行。
SQL> update testrp partition(testrp3) set b = '81_new' where a = 81;
已更新 1 行。
SQL> commit;
提交完成。
SQL> select * from testrp partition(testrp3);
A B
---------- ----------
81 81_new
---------- ----------
81 81_new
--但不可以更新分区键值,所以分区键值的选择要慎重。
--如果确实需要更新分区键值,可以先删除,再插入。
SQL> update testrp partition(testrp3) set a = 2 where a is null;
update testrp partition(testrp3) set a = 2 where a is null
*
ERROR 位于第 1 行:
ORA-14402: 更新分区关键字列将导致分区的更改
SQL> update testrp partition(testrp3) set a = 2 where a is null;
update testrp partition(testrp3) set a = 2 where a is null
*
ERROR 位于第 1 行:
ORA-14402: 更新分区关键字列将导致分区的更改
--6.删除操作也是一样的
SQL> delete from testrp partition(testrp3);
已删除2行。
SQL> select * from testrp;
A B
---------- ----------
1 1
50 50
51 51
80 80
---------- ----------
1 1
50 50
51 51
80 80
SQL> rollback;
回退已完成。
--7.我们看一下对于存在数据的分区表,做分区合并、分裂、删除等操作对于数据的影响。
--7.1合并:被合并的分区已经不存在,该分区中的数据被迁移到了合并后分区中。
SQL> select * from testrp;
SQL> select * from testrp;
A B
---------- ----------
1 1
50 50
51 51
80 80
81 81_new
---------- ----------
1 1
50 50
51 51
80 80
81 81_new
已选择6行。
SQL> select * from testrp partition(testrp1);
A B
---------- ----------
1 1
50 50
---------- ----------
1 1
50 50
SQL> select * from testrp partition(testrp2);
A B
---------- ----------
51 51
80 80
---------- ----------
51 51
80 80
SQL> select * from testrp partition(testrp3);
A B
---------- ----------
81 81_new
---------- ----------
81 81_new
SQL> alter table testrp merge partitions testrp2, testrp3 into partition testrp2;
alter table testrp merge partitions testrp2, testrp3 into partition testrp2
*
ERROR 位于第 1 行:
ORA-14275: 不能将下界分区作为结果分区重用
SQL> alter table testrp merge partitions testrp2, testrp3 into partition testrp3;
表已更改。
SQL> select * from testrp;
A B
---------- ----------
1 1
50 50
51 51
80 80
81 81_new
---------- ----------
1 1
50 50
51 51
80 80
81 81_new
已选择6行。
SQL> select * from testrp partition(testrp1);
A B
---------- ----------
1 1
50 50
---------- ----------
1 1
50 50
SQL> select * from testrp partition(testrp2);
select * from testrp partition(testrp2)
*
ERROR 位于第 1 行:
ORA-02149: 指定的分区不存在
select * from testrp partition(testrp2)
*
ERROR 位于第 1 行:
ORA-02149: 指定的分区不存在
SQL> select * from testrp partition(testrp3);
A B
---------- ----------
51 51
80 80
81 81_new
---------- ----------
51 51
80 80
81 81_new
--7.2分裂:分裂后,该分区中的数据按照分区键值分配到新分区中。
SQL> alter table testrp split partition testrp3 at(81) into (
2 partition testrp2 tablespace tp_p2,
3 partition testrp3 tablespace tp_p3
4 );
2 partition testrp2 tablespace tp_p2,
3 partition testrp3 tablespace tp_p3
4 );
表已更改。
SQL> select * from testrp partition(testrp2);
A B
---------- ----------
51 51
80 80
---------- ----------
51 51
80 80
SQL> select * from testrp partition(testrp3);
A B
---------- ----------
81 81_new
---------- ----------
81 81_new
--7.3删除:删除分区后,该分区中的数据被一并删除。慎重使用。
SQL> alter table testrp drop partition testrp3;
表已更改。
SQL> select * from testrp;
A B
---------- ----------
1 1
50 50
51 51
80 80
---------- ----------
1 1
50 50
51 51
80 80
SQL> select * from testrp partition(testrp1);
A B
---------- ----------
1 1
50 50
---------- ----------
1 1
50 50
SQL> select * from testrp partition(testrp2);
A B
---------- ----------
51 51
80 80
---------- ----------
51 51
80 80
SQL> select * from testrp partition(testrp3);
select * from testrp partition(testrp3)
*
ERROR 位于第 1 行:
ORA-02149: 指定的分区不存在
select * from testrp partition(testrp3)
*
ERROR 位于第 1 行:
ORA-02149: 指定的分区不存在
--7.4重命名:对数据没有影响。
SQL> alter table testrp rename partition testrp2 to testrp02
表已更改。
SQL> select * from testrp;
A B
---------- ----------
1 1
50 50
51 51
80 80
---------- ----------
1 1
50 50
51 51
80 80
SQL> select * from testrp partition(testrp1);
A B
---------- ----------
1 1
50 50
---------- ----------
1 1
50 50
SQL> select * from testrp partition(testrp2);
select * from testrp partition(testrp2)
*
ERROR 位于第 1 行:
ORA-02149: 指定的分区不存在
select * from testrp partition(testrp2)
*
ERROR 位于第 1 行:
ORA-02149: 指定的分区不存在
SQL> select * from testrp partition(testrp02);
A B
---------- ----------
51 51
80 80
---------- ----------
51 51
80 80
--8.可以截短指定分区
SQL> alter table testrp truncate partition testrp02;
表已截掉。
SQL> select * from testrp;
A B
---------- ----------
1 1
50 50
---------- ----------
1 1
50 50
SQL> select * from testrp partition(testrp1);
A B
---------- ----------
1 1
50 50
---------- ----------
1 1
50 50
SQL> select * from testrp partition(testrp02);
未选定行
--9.交换分区测试
--9.1 用法
SQL> insert into testrp values(51, '51');
已创建 1 行。
SQL> insert into testrp values(80, '80');
已创建 1 行。
SQL> commit;
提交完成。
SQL> create table testrp_ex as select * from testrp where 1 = 0;
表已创建。
SQL> insert into testrp_ex values(70, '70');
已创建 1 行。
SQL> commit;
提交完成。
SQL> alter table testrp exchange partition testrp02 with table testrp_ex;
表已更改。
SQL> select * from testrp_ex;
A B
---------- ----------
51 51
80 80
---------- ----------
51 51
80 80
SQL> select * from testrp partition(testrp02);
A B
---------- ----------
70 70
---------- ----------
70 70
--9.2 我们把数据交换回去,再测试一下交换分区的限制
--9.2.1被交换的表里的数据必须在交换分区的范围内
SQL> alter table testrp exchange partition testrp02 with table testrp_ex;
表已更改。
SQL> insert into testrp_ex values(30,'30');
已创建 1 行。
SQL> commit;
提交完成。
SQL> select * from testrp_ex;
A B
---------- ----------
70 70
30 30
---------- ----------
70 70
30 30
SQL> alter table testrp exchange partition testrp02 with table testrp_ex;
alter table testrp exchange partition testrp02 with table testrp_ex
*
ERROR 位于第 1 行:
ORA-14099: 未对指定分区限定表中的所有行
alter table testrp exchange partition testrp02 with table testrp_ex
*
ERROR 位于第 1 行:
ORA-14099: 未对指定分区限定表中的所有行
SQL> delete from testrp_ex where a = 30;
已删除 1 行。
SQL> commit;
提交完成。
--9.2.2 要交换的表和分区列数必须相同,但列名可以不同
SQL> alter table testrp_ex add c varchar2(10);
表已更改。
SQL> alter table testrp exchange partition testrp02 with table testrp_ex;
alter table testrp exchange partition testrp02 with table testrp_ex
*
ERROR 位于第 1 行:
ORA-14096: ALTER TABLE EXCHANGE PARTITION 中的表必须具有相同的列数
alter table testrp exchange partition testrp02 with table testrp_ex
*
ERROR 位于第 1 行:
ORA-14096: ALTER TABLE EXCHANGE PARTITION 中的表必须具有相同的列数
SQL> desc testrp
名称 是否为空? 类型
----------------------------------------- -------- --------------------------
A NUMBER(10)
B VARCHAR2(10)
SQL> drop table testrp_ex;
表已丢弃。
SQL> create table testrp_ex ( aa number(10), bb varchar2(10));
表已创建。
SQL> insert into testrp_ex values(70,'70');
已创建 1 行。
SQL> commit;
提交完成。
SQL> alter table testrp exchange partition testrp02 with table testrp_ex;
表已更改。
SQL> select * from testrp_ex;
AA BB
---------- ----------
51 51
80 80
---------- ----------
51 51
80 80
SQL> select * from testrp partition(testrp02);
A B
---------- ----------
70 70
---------- ----------
70 70
SQL>