Oracle
 sql >> Base de Dados >  >> RDS >> Oracle

Criando uma visualização materializada que é atualizada a cada 5 minutos


Eu demonstrei em etapas onde uma visualização materializada é atualizada a cada one minute ,para ter um mv que atualiza após 5 minutos, use next(sysdate+5/1440)

Passo 1:
Create table temp (A int);

Passo 2:
Create Materialized view temp_mv
      refresh complete start with (sysdate) next  (sysdate+1/1440) with rowid
        as select * from temp;

Etapa 3:
select count(*) from temp;

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

Passo 4:
select count(*) from temp_mv;

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

Etapa 5:
begin
      for i in 1..10 loop
         insert into temp values (i+1);
      end loop;
end;
/

Etapa 6:
commit;

Etapa 7:
select count(*) from temp;

      COUNT(*)
     ----------
        10

Etapa 8:
select count(*) from temp_mv;

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

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

       TO_CH
       -----
       04:28

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

       TO_CH
        -----
       04:29

Etapa 11:
select count(*) from temp;

      COUNT(*)
     ----------
        10

Etapa 12:
select count(*) from temp_mv;

      COUNT(*)
      ----------
         10