Демонстрирах на стъпки, когато материализираният изглед се опреснява след всяка one minute
, за да имате mv, който се опреснява след 5 минути, използвайте 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