Oracle9i现在有两个方法可以完成分割:range分割和新的list分割。但是range分割需要标量数值,而list分割答应使用非标量数值。 要区分range分割和list分割,让我们看一个简单的例子。现在我们看一个range分割的表,然后使用area_code来分割数据:
Create table customer ( Last_name varchar2(30), area_code number . . . ) PARTITION BY RANGE (area_code) ( PARTITION part_505 values less than(505), PARTITION part_212 values less than(212), PARTITION part_919 values less than(919), PARTITION part_252 values less than(252), PARTITION part_415 values less than(MAXVALUE) ); 不像range分割需要一个NUMBER或者DATE标量值,list分割可以用于根据你想用的任何值来分割数据。下面是一个customer数据库的例子,其数据根据州(state)进行分割: create table customer (col values) partition by list (state_name) partition yankees values ('New York','Maine'), partition rebels values ('North Carolina', South Carolina'); 我们可以看到,list分割为大型Oracle表增加了很大的灵活性,而且在进行逻辑划分行数据的时候给了你更多的选择。
|