Oracle FAQ | Your Portal to the Oracle Knowledge Grid |
![]() |
![]() |
Home -> Community -> Mailing Lists -> Oracle-L -> RE: Materialized Views - Overall Approach/Steps - for review
Thanks Jared for the review.
Qs Any thumb rules / basic principles to estimate amount of Undo Space needed on Target/Slave Site? Qs Any best practices Docs/Links etc on the usage of MV?
Our Production DB is a Hybrid Banking Application. There is a mix of OLTP Trans & Reports.
DB size is 600 GB.
Largest Table is 70 GB
Will provide any info needed.
Thanks Vivek,
I modifiied my own procedure after reviewing this.
Somehow I had determined that the target table needed a primary key in order to be used as 'prebuilt', but that was incorrect.
After reviewing this I modified my procedures and saved several hours and 40 gig of rollback space.
Jared
On 9/2/05, VIVEK_SHARMA <VIVEK_SHARMA_at_infosys.com> wrote:
Jared,Tim, Folks
Following is our overall approach/Steps of transfer of DB from SUN to AIX using MV for your review.
At Source/Master DB:-
2 primary key ( empno );
Table altered.
(Since Unique indexes already PRE-Exist, above PK creation will be very Fast)
scott_at_ORA9IR1> create materialized view log on emp;
Materialized view log created.
At Target / Slave DB:-
Table created.
ops$tkyte_at_ORA9IR2> create materialized view emp
2 on prebuilt table
3 refresh complete
4 as
5 select * from emp_at_ora9ir1;
Materialized view created.
ops$tkyte_at_ORA9IR2>
ops$tkyte_at_ORA9IR2> begin
2 dbms_refresh.make(
3 name =>'group1',
4 list =>'emp,dept',
5 next_date =>sysdate,
6 interval =>'sysdate+1/24',
7 implicit_destroy =>true);
8 end;
9 /
PL/SQL procedure successfully completed.
ops$tkyte_at_ORA9IR2> exec dbms_refresh.refresh( 'GROUP1' );
PL/SQL procedure successfully completed.
ops$tkyte_at_ORA9IR2> alter materialized view emp refresh fast;
Materialized view altered.
At Source/Master DB:-
1 row updated.
scott_at_ORA9IR1> commit;
Commit complete.
(Above done to simulate Production updates on Source DB)
At Target / Slave DB:-
ops$tkyte_at_ORA9IR2> exec dbms_refresh.refresh( 'GROUP1' );
PL/SQL procedure successfully completed.
ops$tkyte_at_ORA9IR2> drop materialized view emp;
Materialized view dropped.
ops$tkyte_at_ORA9IR2> select count(*) from emp;
COUNT(*)
![]() |
![]() |