ITPub博客

首页 > 大数据 > 数据挖掘 > 物化视图分区实验

物化视图分区实验

原创 数据挖掘 作者:abin1703 时间:2019-09-18 10:01:21 0 删除 编辑

今天同事需要将原有的雾化试图做一个分区的雾化试图,可能效率会更快一些,让帮忙看一下,以下是做的实验验证一下,实验如下:

create table t3 (id number primary key,day_date varchar2(30));
create MATERIALIZED VIEW log on t3 with rowid including new values;
 create materialized view mv_test_id partition by range(day_date)
  (
  PARTITION P1 VALUES LESS THAN (TO_DATE('20170101', 'YYYYMMDD'))
    ) tablespace users
       nologging
       build immediate refresh FAST
        WITH PRIMARY KEY
         on demand
     enable query rewrite
   as SELECT id,day_date from t3;
 

select * from mv_test_id;
alter table  mv_test_id add partition part2 values less than (TO_DATE('20170201', 'YYYYMMDD'));


自动增加分区需要定义job  
 
  CREATE OR REPLACE PROCEDURE guan_add_partition
--为一个用户下所有分区表自动增加分区.分区的列为date类型,分区名类似:p200706.
 AS
  v_table_name     VARCHAR2(50);
  v_partition_name VARCHAR2(50);
  v_month          CHAR(6);
  v_add_month_1    CHAR(6);
  v_sql_string     VARCHAR2(2000);
  v_add_month      VARCHAR2(20);
  CURSOR cur_part IS
    SELECT DISTINCT u.table_name, MAX(p.partition_name) max_part_name
      FROM user_tables u, user_tab_partitions p
     WHERE u.table_name = p.table_name
       AND u.partitioned = 'YES'
     GROUP BY u.table_name;
BEGIN
  SELECT to_char(SYSDATE, 'yyyymm') INTO v_month FROM dual;
  SELECT to_char(add_months(SYSDATE, 1), 'yyyymm')
    INTO v_add_month_1
    FROM dual;
  SELECT to_char(add_months(trunc(SYSDATE, 'mm'), 2), 'yyyy-mm-dd')
    INTO v_add_month
    FROM dual;
  OPEN cur_part;
  LOOP
    FETCH cur_part
      INTO v_table_name, v_partition_name;
    EXIT WHEN cur_part%NOTFOUND;
    IF to_number(substr(v_partition_name, 2)) <=
       to_number(substr(v_month, 1)) THEN
      v_sql_string := 'alter table ' || v_table_name || ' add partition p' ||
                      v_add_month_1 || ' VALUES LESS THAN ( to_date(''' ||
                      v_add_month ||
                      ''',''yyyy-mm-dd'') ) tablespace users';
      EXECUTE IMMEDIATE v_sql_string;
    ELSE
      NULL;
    END IF;
  END LOOP;
  CLOSE cur_part;
END;

定义schedule,每个月月初调用创建分区存储过程。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/30345407/viewspace-2657339/,如需转载,请注明出处,否则将追究法律责任。

下一篇: 没有了~
请登录后发表评论 登录
全部评论

注册时间:2015-07-13

  • 博文量
    158
  • 访问量
    207119