programing

5분마다 새로 고쳐지는 구체화된 보기 만들기

codeshow 2023. 8. 5. 11:06
반응형

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분 사용 후 재충전되는 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;
/

이렇게 하면 야간이나 주말을 제외하는 등 더 많은 구성 옵션을 사용할 수 있습니다.

언급URL : https://stackoverflow.com/questions/10061597/creating-materialized-view-that-refreshes-every-5-min

반응형