创建每 5 分钟刷新一次的物化视图

Creating materialized view that refreshes every 5 min(创建每 5 分钟刷新一次的物化视图)
本文介绍了创建每 5 分钟刷新一次的物化视图的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

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

I created a materialized view that refreshed every 5 min but when I do insert and perform select on materialized view I get same old data? Do I need to refresh manually?

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

推荐答案

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

I have demonstrated in steps where a materialized view refresh after every one minute ,for having a mv which refresh after 5 minute use next(sysdate+5/1440)

第一步:

Create table temp (A int);

步骤 2:

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

第八步:

select count(*) from temp_mv;

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

第九步:

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

       TO_CH
       -----
       04:28

第 10 步:

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

这篇关于创建每 5 分钟刷新一次的物化视图的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

SQL to Generate Periodic Snapshots from Transactions Table(用于从事务表生成定期快照的SQL)
MyBatis support for multiple databases(MyBatis支持多个数据库)
Oracle 12c SQL: Missing column Headers in result(Oracle 12c SQL:结果中缺少列标题)
SQL query to find the number of customers who shopped for 3 consecutive days in month of January 2020(查询2020年1月连续购物3天的客户数量)
How to get top 10 data weekly (This week, Previous week, Last month, 2 months ago, 3 month ago)(如何每周获取前十大数据(本周、前一周、上个月、2个月前、3个月前))
Select the latest record for an Id per day - Oracle pl sql(选择每天ID的最新记录-Oracle pl SQL)