Как сделать автоматическое обновление материализованных представлений - PullRequest
0 голосов
/ 08 января 2019

Я хочу автоматически обновить материализованное представление после вставки данных в таблицы при создании материализованного представления.

Я попробовал следующий код (обновление завершено, начните с Создание материализованного представления, которое обновляется каждые 5 минут ), но не работает. Также этот код является решением для обновления каждые 1 минуту.

Я хочу решение при вставке данных. Возможно ли это?

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

1 Ответ

0 голосов
/ 08 января 2019

Вы можете попробовать это, но это не будет работать для более сложных представлений.

  --create table
    create table temp (a int not null primary key);


    -- create table log; 
    create materialized view log on temp
    with primary key
    including new values;

    --create view 
    create materialized view temp_mv
    build immediate 
    refresh fast
    on commit
    as
    select * from temp;


    -- populate table 
    insert into  temp select level from dual connect by level <100;

    select * from temp_mv; -- no value 

    commit; -- view is refreshed


    select * from temp_mv; -- all values
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...