视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
Oracle在线扩展分区
2020-11-09 12:52:04 责编:小采
文档


在对Oracle分区表操作是,当一个分区已经有了最大的分区,如何再次扩展分区呢?简单的方式是先删除最大分区,然后添加需要的分区

在对Oracle分区表操作是,当一个分区已经有了最大的分区,如何再次扩展分区呢?简单的方式是先删除最大分区,,然后添加需要的分区,再次建立最大分区,如果对于7*24小时的系统,可能不行。哪有什么办法呢?下面来做个试验:

SQL> select * from v$version;
BANNER
----------------------------------------------------------------
Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - bi
PL/SQL Release 10.2.0.1.0 - Production
CORE 10.2.0.1.0 Production
TNS for -bit Windows: Version 10.2.0.1.0 - Production
NLSRTL Version 10.2.0.1.0 - Production


SQL> drop table test purge;
SQL> create table test
(
id number,
record_date date
)partition by range(record_date)
(
partition p_2013 values less than(to_date('2013-01-01','yyyy-MM-dd')),
partition p_2014 values less than(to_date('2014-01-01','yyyy-MM-dd')),
partition p_max values less than (maxvalue)
);

SQL> insert into test values(1,to_date('2012-10-01','yyyy-MM-dd'));
SQL> insert into test values(2,to_date('2013-10-01','yyyy-MM-dd'));
SQL> insert into test values(3,to_date('2014-10-01','yyyy-MM-dd'));
SQL> commit;
SQL> select partition_name from user_tab_partitions
where table_name = 'TEST'
order by partition_position;
PARTITION_NAME
------------------------------
P_2013
P_2014
P_MAX

SQL> select * from test partition(p_2013);
ID RECORD_DATE
---------- --------------
1 01-10月-12

SQL> select * from test partition(p_2014);
ID RECORD_DATE
---------- --------------
2 01-10月-13

SQL> select * from test partition(p_max);
ID RECORD_DATE
---------- --------------
3 01-10月-14

SQL> alter table test add partition p_2015 values
less than(to_date('2015-10-01','yyyy-MM-dd'));
alter table test add partition p_2015 values
*
第 1 行出现错误:
ORA-14074: 分区界限必须调整为高于最后一个分区界限

SQL> alter table test split partition p_max at (to_date('2015-01-01','yyyy-MM-dd'))
into (partition p_2015, partition p_max) update global indexes;

SQL> select partition_name from user_tab_partitions
where table_name = 'TEST'
order by partition_position;
PARTITION_NAME
------------------------------
P_2013
P_2014
P_2015
P_MAX

SQL> insert into test values(4,to_date('2015-10-01','yyyy-MM-dd'));
SQL> commit;
SQL> select * from test partition(p_2015);
ID RECORD_DATE
---------- --------------
3 01-10月-14

SQL> select * from test partition(p_max);
ID RECORD_DATE
---------- --------------
4 01-10月-15

浅谈Oracle分区表之范围分区

Oracle分区表迁移

Oracle分区表使用实例

Oracle分区表 (Partition Table) 的创建及管理

本文永久更新链接地址:

下载本文
显示全文
专题