To refresh a Materialized view we need DBMS_SNAPSHOT.REFRESH procedure.
data:image/s3,"s3://crabby-images/21a70/21a70013aab9131765cc04c413a297e41a47188f" alt=""
Steps.
CREATE TABLE demo_m
(
id NUMBER (10) primary key,
name VARCHAR2 (400)
);
/
INSERT INTO DEMO_M (
ID, NAME)
VALUES (1001, 'VIKAS' );
/
SELECT * FROM demo_m;
data:image/s3,"s3://crabby-images/d288e/d288eadb89f5865df149ae6c34eb67eb728cd863" alt=""
One record is available in the table.
Create Materialized view.
CREATE MATERIALIZED VIEW emp_m_view
--BUILD IMMEDIATE --
REFRESH
--Fast
--Complete
FORCE
ON --COMMIT
DEMAND
AS
SELECT * FROM demo_m;
/
Select * from emp_m_view;
data:image/s3,"s3://crabby-images/bce50/bce50ad2db8c9013660f5bf771278f4b30cc9b5b" alt=""
One record is also in view. Now insert into table.
INSERT INTO DEMO_M (
ID, NAME)
VALUES (1002, 'PANDEY' );
SELECT * FROM demo_m;
data:image/s3,"s3://crabby-images/001d7/001d7ec637f3b87459feda6725510df40f43a6c6" alt=""
One record added.
check view-
Select * from emp_m_view;
data:image/s3,"s3://crabby-images/e0f3b/e0f3be79cf1bcac8fb0c2cfa353cf5dfc8cf1ce2" alt=""
Still one record which was inserted before creating materialized view. now to refresh this records in view we need to run the DBMS_SNAPSHOT.REFRESH procedure.
BEGIN
DBMS_SNAPSHOT.REFRESH('emp_m_view'); -- View name as parameter
END;
/
Check view data.
Select * from emp_m_view;
data:image/s3,"s3://crabby-images/f7b0e/f7b0e75ac072600d4f6cd118af0dad4e0fa15550" alt=""
Now data is refreshed in materialized view.