【问题标题】:Creating materialized view that refreshes every 5 min创建每 5 分钟刷新一次的物化视图
【发布时间】:2017-04-20 20:30:22
【问题描述】:

我创建了一个每 5 分钟刷新一次的物化视图,但是当我在物化视图上插入并执行选择时,我得到了相同的旧数据?需要手动刷新吗?

CREATE MATERIALIZED VIEW MVW_TEST
REFRESH FORCE ON DEMAND 
START WITH TO_DATE('01-01-2009 00:01:00', 'DD-MM-YYYY HH24:MI:SS') NEXT SYSDATE + 1/1152 
As select * from TEST12

【问题讨论】:

  • 尝试删除ON DEMAND
  • 您在基表上的插入是否已提交?如果没有,您将看不到数据。另外,您当然必须等待。
  • @RogerCornejo 谢谢 :) 的建议 :)

标签: oracle oracle11g


【解决方案1】:

我已经演示了在每个 one minute 之后刷新物化视图的步骤,因为 5 分钟后刷新的 mv 使用 next(sysdate+5/1440)

第一步:

Create table temp (A int);

第二步:

Create Materialized view temp_mv
      refresh complete start with (sysdate) next  (sysdate+1/1440) with rowid
        as select * from temp;

第三步:

select count(*) from temp;

       COUNT(*)
      ----------
          0

第四步:

select count(*) from temp_mv;

       COUNT(*)
      ----------
          0

第五步:

begin
      for i in 1..10 loop
         insert into temp values (i+1);
      end loop;
end;
/

第六步:

commit;

第七步:

select count(*) from temp;

       COUNT(*)
     ----------
        10

第8步:

select count(*) from temp_mv;

       COUNT(*)
       ----------
          0

第九步:

select to_char(sysdate,'hh:mi') from dual;

       TO_CH
       -----
       04:28

第十步:

select to_char(sysdate,'hh:mi') from dual;

       TO_CH
        -----
       04:29

第11步:

select count(*) from temp;

      COUNT(*)
     ----------
        10

第12步:

select count(*) from temp_mv;

      COUNT(*)
      ----------
         10

【讨论】:

  • 如果查询的运行时间超过分配的时间怎么办?
  • @Kitex:你需要小心,并在此基础上增加你的刷新时间。
  • 这不对。根据当前刷新完成的时间安排下一次刷新。
  • 我有 36 个物化视图:我不希望它们都尝试同时更新。我尝试了很多不同的事情,但下一次运行时间总是设置为 3 分钟后。这是一个示例,我希望它在午夜后 45 分钟开始,但最终在午夜后 3 分钟结束:START WITH TRUNC(SYSDATE+1) + 3/96
  • @BillWorthington 你想问一个单独的问题
【解决方案2】:

您还可以创建调度程序作业:

BEGIN
  SYS.DBMS_SCHEDULER.CREATE_JOB
    (
       job_name        => 'DBAPER.MVW_TEST_REFRESH'
      ,start_date      => TO_TIMESTAMP_TZ('2011/09/02 00:00:00.000000 US/Central','yyyy/mm/dd hh24:mi:ss.ff tzr')
      ,repeat_interval => 'FREQ=DAILY;BYHOUR=6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22;BYMINUTE=0,5,10,15,20,25,30,35,40,45,50,55'
      ,end_date        => NULL
      ,job_class       => 'DEFAULT_JOB_CLASS'
      ,job_type        => 'PLSQL_BLOCK'
      ,job_action      => 'BEGIN 
                            DBMS_MVIEW.REFRESH(''MVW_TEST'',''C'');
                            END;'
      ,comments        => 'Job to refresh materialized view MVW_TEST.'
    );
END;
/

这样您就有更多的配置选项,例如排除夜间或周末。

【讨论】:

  • 这是最明智的做法。您可以完全控制刷新周期,可以在需要时轻松禁用刷新,而无需更改物化视图定义,并且可以使用 user_scheduler_XXX 视图对其进行监控。
猜你喜欢
  • 1970-01-01
  • 2013-11-17
  • 2016-11-10
  • 2014-04-24
  • 2017-06-11
  • 2017-06-25
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多