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分後に更新されるmvがあるためですnext(sysdate+5/1440)
ステップ1:
_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;
_
ステップ3:
_select count(*) from temp;
COUNT(*)
----------
0
_
ステップ4:
_select count(*) from temp_mv;
COUNT(*)
----------
0
_
ステップ5:
_begin
for i in 1..10 loop
insert into temp values (i+1);
end loop;
end;
/
_
ステップ6:
_commit;
_
ステップ7:
_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
_
スケジューラジョブを作成することもできます。
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;
/
これにより、たとえば夜間や週末を除外するなど、より多くの構成オプションを使用できます。