2012-04-08 23 views
9

5分ごとにリフレッシュするマテリアライズド・ビューを作成しましたが、マテリアライズド・ビューを選択して挿入すると、古いデータが取得されます。手動で更新する必要はありますか?5分ごとにリフレッシュするマテリアライズド・ビューの作成

私は 5分間の使用後にリフレッシュMV next(sysdate+5/1440)

ステップ1持つために、すべてのone minute後にマテリアライズド・ビューのリフレッシュステップで証明されている

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 
+1

「オンデマンド」を削除してください –

+1

あなたのベーステーブルに挿入されていますか?そうでない場合は、データは表示されません。プラスあなたはもちろん待つ必要があります。 –

+0

@RogerCornejoありがとう:)提案のため: – kinkajou

答えて

22

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 

STEP12:

select count(*) from temp_mv; 

     COUNT(*) 
     ---------- 
     10 
+0

クエリの実行時間よりも多くの時間がかかる場合はどうなりますか? – kinkajou

+0

@Kitex:気をつけてリフレッシュ時間を増やす必要があること。 –

3

また、スケジューラ・ジョブを作成することができます

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; 
/

あなたは、たとえば夜間や週末を除くなどのより多くの設定オプションを持ってその方法を。

関連する問題