创建每隔5分钟刷新一次的物化视图
问题描述:
我创建了一个物化视图,每5分钟刷新一次,但是当我插入并在物化视图上执行选择时,我会得到相同的旧数据?我需要手动刷新吗?创建每隔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
答
我在步骤已经证明,每一个one minute
之后的物化视图刷新,对于具有 后5分钟使用该刷新next(sysdate+5/1440)
第一步一个MV:
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;
第3步:
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
步骤9:
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
+0
如果查询需要比分配时间运行更多时间,该怎么办? – kinkajou 2012-04-08 11:15:40
+0
@Kitex:你需要保重,并根据这个增加你的刷新时间。 – 2012-04-08 11:21:16
答
您还可以创建一个调度工作:
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;
/
你有更多的配置选项,如不包括夜间或周末例如这样。
尝试删除'ON DEMAND' – 2012-04-08 09:02:10
是您在基础表上插入的东西吗?如果不是,你将不会看到数据。另外,你必须等待。 – 2012-04-09 13:06:14
@RogerCornejo感谢:)对于建议:) – kinkajou 2012-04-09 13:43:13