文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Oracle范围分区应用实例

2024-04-02 19:55

关注

概述

    范围分区(Range partition):就是根据表的某个字段的值,以固定的一个范围作为一个分区来划分数据。

 实例:

  1. 创建销售部门销售数据清单表:

    create table sales_list
    (order_id number(5),
    sales_name varchar2(20),
    order_amount number(10),
    order_date date
    )
    partition by range (order_date)
    (partition sales_201401 values less than(to_date('2014-02-01','yyyy-mm-dd')),
    partition sales_201402 values less than(to_date('2014-03-01','yyyy-mm-dd')),
    partition sales_201403 values less than(to_date('2014-04-01','yyyy-mm-dd')),
    partition sales_201404 values less than(to_date('2014-05-01','yyyy-mm-dd')),
    partition sales_201405 values less than(to_date('2014-06-01','yyyy-mm-dd')),
    partition sales_201406 values less than(to_date('2014-07-01','yyyy-mm-dd')),
    partition sales_201407 values less than(to_date('2014-08-01','yyyy-mm-dd')),
    partition sales_201408 values less than(to_date('2014-09-01','yyyy-mm-dd')),
    partition sales_201409 values less than(to_date('2014-10-01','yyyy-mm-dd')),
    partition sales_201410 values less than(to_date('2014-11-01','yyyy-mm-dd')),
    partition sales_201411 values less than(to_date('2014-12-01','yyyy-mm-dd')),
    partition sales_201412 values less than(to_date('2015-01-01','yyyy-mm-dd')),
    partition sales_201501 values less than(to_date('2015-02-01','yyyy-mm-dd')),
    partition sales_201502 values less than(to_date('2015-03-01','yyyy-mm-dd'))
    );

    创建了14个分区,14个段

    SQL> col partition_name format a20
    SQL> col segment_name format a20
    SQL> select segment_name,partition_name from user_segments where segment_name='SALES_LIST';

    SEGMENT_NAME      PARTITION_NAME
    -------------------- --------------------
    SALES_LIST      SALES_201401
    SALES_LIST      SALES_201402
    SALES_LIST      SALES_201403
    SALES_LIST      SALES_201404
    SALES_LIST      SALES_201405
    SALES_LIST      SALES_201406
    SALES_LIST      SALES_201407
    SALES_LIST      SALES_201408
    SALES_LIST      SALES_201409
    SALES_LIST      SALES_201410
    SALES_LIST      SALES_201411
    SALES_LIST      SALES_201412
    SALES_LIST      SALES_201501
    SALES_LIST      SALES_201502

        14 rows selected.

 

创建过程用于删除旧的分区并添加新的分区:

CREATE OR REPLACE PROCEDURE drop_add_partition AS
  v_part_name VARCHAR2(100);
  v_next_name VARCHAR2(100);
  v_over_time NUMBER;
  v_string    VARCHAR2(10);
  v_date      DATE;
BEGIN
  SELECT MIN(partition_name)
    INTO v_part_name
    FROM user_tab_partitions
   WHERE table_name = 'SALES_LIST'; --找到当前最早的分区
  SELECT MAX(partition_name)
    INTO v_next_name
    FROM user_tab_partitions
   WHERE table_name = 'SALES_LIST'; --找到当前最晚的分区
  SELECT substr(to_char(add_months(to_date(substr(v_next_name, 7, 6),
                                           'yyyy-mm'),
                                   1),
                        'yyyymmdd'),
                1,
                6)
    INTO v_next_name
    FROM dual; --拼接下一个新的分区的名称串
  SELECT round(months_between(SYSDATE,
                              to_date(substr(v_part_name, 7, 6), 'yyyy-mm')))
    INTO v_over_time
    FROM dual;
  --计算当前时间和最早分区的之间间隔的月数
  v_string := to_char(add_months(to_date(v_next_name, 'yyyy-mm'), 1),
                      'yyyy-mm');
  v_date   := to_date(substr(v_string, 1, 4) || '-' ||
                      substr(v_string, 6, 2) || '-01',
                      'yyyy-mm-dd');
  --拼接新的分区在创建的时候需要指定的截至时间点的串
  IF v_over_time > 12
  THEN
    EXECUTE IMMEDIATE 'alter table sales_list drop partition ' ||
                      v_part_name; --删除旧的分区
    EXECUTE IMMEDIATE 'alter table sales_list add partition SALES_' ||
                      REPLACE(v_next_name, '-', '') ||
                      ' values less than (''' || v_date || ''')'; --添加新的分区
  END IF;
EXCEPTION
  WHEN OTHERS THEN
    --异常处理
    dbms_output.put_line(to_char(SQLCODE));
    dbms_output.put_line(SQLERRM);
END;

SQL> set serveroutput on
SQL> exec drop_add_partition;

PL/SQL procedure successfully completed.

SQL> select segment_name,partition_name from user_segments where segment_name='SALES_LIST';

SEGMENT_NAME      PARTITION_NAME
-------------------- --------------------
SALES_LIST      SALES_201402
SALES_LIST      SALES_201403
SALES_LIST      SALES_201404
SALES_LIST      SALES_201405
SALES_LIST      SALES_201406
SALES_LIST      SALES_201407
SALES_LIST      SALES_201408
SALES_LIST      SALES_201503
SALES_LIST      SALES_201409
SALES_LIST      SALES_201410
SALES_LIST      SALES_201411
SALES_LIST      SALES_201412
SALES_LIST      SALES_201501
SALES_LIST      SALES_201502

14 rows selected.

创建后台作业:
declare
  job number;
begin
  dbms_job.submit(job,'drop_add_partition;',sysdate,'sysdate+1');  --每天运行一次,创建这个job的时候就要执行一次
  commit;
end;

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯