Chinaunix首页 | 论坛 | 博客
  • 博客访问: 103593248
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类: Oracle

2008-04-01 20:25:35

来源:赛迪网    作者:36933

Oracle11g有一个新增的特性INTERVAL分区,此种范围分区不需要定义MAXVALUE,Oracle会根据分区定义的INTERVAL来动态的分配新分区来容纳超过范围的数据。

Oracle在分配新分区的时候只会给存在数据的分区进行分配,对于不存在数据的分区并不会马上分配,而是在需要的时候才去分配。

分区分配策略的示例:

SQL> CREATE TABLE T_INTERVAL_PART 
2 PARTITION BY RANGE (CREATED) 
3 INTERVAL (NUMTOYMINTERVAL(1, 'MONTH')) 
4 (PARTITION P1 VALUES LESS THAN (TO_DATE('2007-9-1', 'YYYY-MM-DD'))) 
5 AS SELECT * FROM DBA_OBJECTS;

表已创建。

  SQL> SELECT TABLE_NAME, PARTITION_NAME, HIGH_VALUE FROM USER_TAB_PARTITIONS 
  2 WHERE TABLE_NAME = 'T_INTERVAL_PART' 
  3 ORDER BY 2; 
  TABLE_NAME PARTITION_NAME HIGH_VALUE 
  --------------- -------------- ---------------------------------
  T_INTERVAL_PART P1 TO_DATE(' 2007-09-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GR 
  T_INTERVAL_PART SYS_P113 TO_DATE(' 2007-11-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALEND 
  T_INTERVAL_PART SYS_P114 TO_DATE(' 2007-10-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALEND

以上这个例子就是在介绍INTERVAL分区时使用的例子,不过这个例子中存在一个比较奇怪的显现,那就是对于2007年11月的分区对于的分区名称中的序号反而小于2007年10月的。

看到这个现象,第一个反应就是认为,Oracle根据INTERVAL的值的上限,从高到低依次创建分区,但是随后的测试发现并非如此:

SQL> SELECT TABLE_NAME, PARTITION_NAME, 
    HIGH_VALUE FROM USER_TAB_PARTITIONS 
  2 WHERE TABLE_NAME = 'T_INTERVAL_PART' 
  3 ORDER BY 2; 
  TABLE_NAME PARTITION_NAME HIGH_VALUE 
  --------------- -------------- ---------------------------
  T_INTERVAL_PART P1 TO_DATE(' 2007-09-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GR 
  T_INTERVAL_PART SYS_P113 TO_DATE(' 2007-11-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALEND 
  T_INTERVAL_PART SYS_P114 TO_DATE(' 2007-10-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALEND 
  T_INTERVAL_PART SYS_P115 TO_DATE(' 2008-12-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALEND

Oracle并没有创建从07年12月到08年12月之间的所有的分区,而是仅仅创建了08年12月份的分区。这说明Oracle会根据插入数据的分区键值来分配所需的分区,中间没有包含数据的分区不会被创建。

同时也解释了为什么07年11月分区的分区序号小于10月份的,这是由于在建立分区表并插入数据的过程中,首先出现了11月份的记录,而后才出现了10月份的。

下面验证一下这个结论:

SQL> SELECT * FROM (SELECT ROWNUM RN, OWNER, OBJECT_NAME, CREATED FROM DBA_OBJECTS) 
  2 WHERE CREATED >= TO_DATE('2007-10-1', 'YYYY-MM-DD') 
  3 AND ROWNUM = 1; 
  RN OWNER OBJECT_NAME CREATED 
  ---------- ------------------------------ 
  68234 YANGTK T_INTERVAL_PART 2007-10-21 02:16:06 
  SQL> SELECT * FROM
(SELECT ROWNUM RN, OWNER, OBJECT_NAME, CREATED FROM DBA_OBJECTS) 
  2 WHERE CREATED >= TO_DATE('2007-9-1', 'YYYY-MM-DD') 
  3 AND CREATED < TO_DATE('2007-10-1', 'YYYY-MM-DD') 
  4 AND ROWNUM = 1; 
  RN OWNER OBJECT_NAME CREATED 
  ---------- ------------------------------ 
  68240 SYS T_PART 2007-09-15 16:25:15

由于查询DBA_OBJECTS视图的时候,先查询到创建时间为10月21日的记录,因此,INTERVAL分区表先建立了上限为11月1日的分区,随后建立了上限为10月1日的分区。

SQL> ROLLBACK;

回退已完成。

SQL> SELECT TABLE_NAME, PARTITION_NAME, HIGH_VALUE FROM USER_TAB_PARTITIONS 
  2 WHERE TABLE_NAME = 'T_INTERVAL_PART' 
  3 ORDER BY 2; 
  TABLE_NAME PARTITION_NAME HIGH_VALUE 
  --------------- -------------- 
  T_INTERVAL_PART P1 TO_DATE(' 2007-09-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GR 
  T_INTERVAL_PART SYS_P113 TO_DATE(' 2007-11-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALEND 
  T_INTERVAL_PART SYS_P114 TO_DATE(' 2007-10-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALEND 
  T_INTERVAL_PART SYS_P115 TO_DATE(' 2008-12-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALEND

注释:即便触发Oracle分配新的分区的数据被回滚了,新增分区也不会被删除。从这一点我们就可以推断,INTERVAL分区的分区分配采用的就是自治事务。

阅读(284) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~