oracle 建立分区表

最近一段时间在做数据统计报表用到了表分区,所以最近就看了看,拿来研究研究。 

一.范围分区
范围分区将数据基于范围映射到每一个分区,这个范围是你在创建分区时指定的分区键决定的。

--例一取值范围:
CREATE TABLE CUSTOMER
(
    CUSTOMER_ID NUMBERNOTNULL PRIMARY KEY,
    FIRST_NAME  VARCHAR2(30)NOTNULL,
    LAST_NAME   VARCHAR2(30)NOTNULL,
    PHONE        VARCHAR2(15)NOTNULL,
    EMAIL        VARCHAR2(80),
    STATUS      CHAR(1)
)
PARTITION BY RANGE (CUSTOMER_ID)
(
    PARTITION CUS_PART1VALUESLESS THAN (100000) TABLESPACE CUS_TS01,
    PARTITION CUS_PART2VALUESLESS THAN (200000) TABLESPACE CUS_TS02,
    PARTITION  CUS_PART3VALUES LESS  THEN (MAXVALUE) TABLESPACE  CUS_TS02
)
--例二按时间划分(随着时间的增长,还需要添加分区表):
CREATE TABLE ORDER_ACTIVITIES
(
    ORDER_ID      NUMBER(7)NOTNULL,
    ORDER_DATE   DATE,
    TOTAL_AMOUNT NUMBER,
    CUSTOTMER_ID NUMBER(7),
    PAID          CHAR(1)
)
PARTITION BY RANGE (ORDER_DATE)
(
  PARTITION ORD_ACT_PART01VALUESLESS THAN (TO_DATE('01- MAY -2003','DD-MON-YYYY')) TABLESPACE ORD_TS01,
  PARTITION ORD_ACT_PART02VALUESLESS THAN (TO_DATE('01-JUN-2003','DD-MON-YYYY')) TABLESPACE ORD_TS02,
  PARTITION ORD_ACT_PART03VALUESLESS THAN (TO_DATE('01-JUL-2003','DD-MON-YYYY')) TABLESPACE ORD_TS03
)

二.列表分区
该分区的特点是某列的值只有几个,基于这样的特点我们可以采用列表分区。

--这个是我在自己电脑上测试的实例,一个sql竞赛的资料库中的数据
create table p_t2(a1 number,a2 varchar2(10),a3 varchar2(30),a4 varchar2(10),a5 number)
    partitionbylist(a2)
    (partition p_tcp values('tcp') tablespace p1,
    partition p_udp values('udp') tablespace p2,
    partition p_icmp values('icmp') tablespace p3)

三.散列分区
这类分区是在列值上使用散列算法,以确定将行放入哪个分区中。当列的值没有合适的条件时,建议使用散列分区。
散列分区为通过指定分区编号来均匀分布数据的一种分区类型,因为通过在I/O设备上进行散列分区,使得这些分区大小一致。

CREATE TABLE HASH_TABLE
(
  COL NUMBER(8),
  INF VARCHAR2(100)
)
PARTITION BYHASH (COL)
(
  PARTITION PART01 TABLESPACE HASH_TS01,
  PARTITION PART02 TABLESPACE HASH_TS02,
  PARTITION PART03 TABLESPACE HASH_TS03
)
--简写:
CREATE TABLE emp
(
    empno NUMBER (4),
    ename VARCHAR2 (30),
    sal   NUMBER
)
PARTITION BY  HASH (empno) PARTITIONS 8
STORE IN(emp1,emp2,emp3,emp4,emp5,emp6,emp7,emp8);

四.组合范围散列分区
这种分区是基于范围分区和列表分区,表首先按某列进行范围分区,然后再按某列进行列表分区,分区之中的分区被称为子分区。

CREATE TABLE SALES
(
PRODUCT_ID VARCHAR2(5),
SALES_DATE DATE,
SALES_COST NUMBER(10),
STATUS VARCHAR2(20)
)
PARTITION BYRANGE(SALES_DATE) SUBPARTITIONBYLIST (STATUS)
(
   PARTITION P1VALUESLESS THAN(TO_DATE('2003-01-01','YYYY-MM-DD'))TABLESPACE rptfact2009
          (
              SUBPARTITION P1SUB1VALUES('ACTIVE') TABLESPACE rptfact2009,
              SUBPARTITION P1SUB2VALUES('INACTIVE') TABLESPACE rptfact2009
          ),
   PARTITION P2VALUESLESS THAN (TO_DATE('2003-03-01','YYYY-MM-DD')) TABLESPACE rptfact2009
          (
              SUBPARTITION P2SUB1VALUES('ACTIVE') TABLESPACE rptfact2009,
              SUBPARTITION P2SUB2VALUES('INACTIVE') TABLESPACE rptfact2009
          )
)

五.复合范围散列分区
这种分区是基于范围分区和散列分区,表首先按某列进行范围分区,然后再按某列进行散列分区。

create table dinya_test
 (
 transaction_id numberprimarykey,
 item_id number(8)notnull,
 item_description varchar2(300),
 transaction_datedate
 )
 partitionbyrange(transaction_date)subpartitionbyhash(transaction_id)  subpartitions 3 storein(dinya_space01,dinya_space02,dinya_space03)
 (
     partition part_01valuesless than(to_date(‘2006-01-01’,’yyyy-mm-dd’)),
     partition part_02valuesless than(to_date(‘2010-01-01’,’yyyy-mm-dd’)),
     partition part_03valuesless than(maxvalue)
 );



创建 Oracle 分区表的一般步骤如下: 1. 创建分区表的分区策略。这个步骤包括选择分区键(用于决定如何分区)、选择分区方法(例如按范围或按列表分区)以及选择分区数目。 2. 创建分区表。在创建时,需要指定分区策略。在中定义分区键列。 3. 创建表分区创建表分区时,可以指定分区的名称、分区的范围(例如分区的日期范围)、分区的存储属性等。 以下是一个示例,展示如何创建一个基于时间范围的分区表: ``` CREATE TABLE sales_data ( id NUMBER, sale_date DATE, product_name VARCHAR2(50), sale_amount NUMBER(12, 2) ) PARTITION BY RANGE(sale_date) INTERVAL(NUMTOYMINTERVAL(1, 'MONTH')) ( PARTITION sales_data_2019 VALUES LESS THAN (TO_DATE('2019-12-01', 'YYYY-MM-DD')), PARTITION sales_data_2020 VALUES LESS THAN (TO_DATE('2020-12-01', 'YYYY-MM-DD')), PARTITION sales_data_2021 VALUES LESS THAN (TO_DATE('2021-12-01', 'YYYY-MM-DD')) ); ``` 在上面的示例中,我们创建了一个基于 `sale_date` 列的分区表。使用 `PARTITION BY RANGE` 语句来指定分区方法和分区键列。使用 `INTERVAL` 子句来指定新分区的时间间隔(这里设置为每个月)。我们还使用 `VALUES LESS THAN` 子句创建了三个分区,分别对应于 2019 年、2020 年和 2021 年。请注意,我们还可以在创建后动态添加新分区。 当表分区创建后,我们可以像处理常规一样处理分区表。例如,可以使用 `INSERT INTO` 语句分区表中插入数据。Oracle 自动将每个插入的行放入适当的分区中。可以使用 `SELECT` 语句查询分区表中的数据,也可以使用其他常规操作来处理分区表
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值