当前位置:Gxlcms > 数据库问题 > oracle 物化视图

oracle 物化视图

时间:2021-07-01 10:21:17 帮助过:20人阅读

 

一、准备条件以及备注

      假设双方数据库都是ORACLE10g,需要同步过来的表名叫:GG_ZLX_ZHU,对方数据库用户名:username,密码:password,SID:CPEES。

 

二、开始干活

      1、首先要创建DB_LINK

      CREATE DATABASE LINK to_cpees

      CONNECT TO "username" identified by "password"

      using "CPEES"

      其中CPEES为新建的到对方数据库的TNS。执行,现在我们就已经创建了到对方数据库的DB_LINK TO_CPEES。

 

       2、创建物化视图快速刷新日志

       因为上面说过,以后视图的刷新将采用增量刷新的方式,因此,为配合增量刷新,oracle要求要在住表上建立物化视图日志。

       CREATE MATERIALIZED VIEW LOG ON GG_ZLX_ZHU        WITH PRIMARY KEY        INCLUDING NEW VALUES;

       (上面的SQL要在远程数据库上执行,不能在本地执行)

 

       3、创建物化视图

       物化视图,从名字上面来开,它应该是属于视图,但是确实物化。其物化是针对普通视图并没有真正的物理存储而言,其实可以简单的把物化视图看做一个物理表(不再做具体解释)。

       CREATE MATERIALIZED VIEW GG_ZLX_ZHU --创建物化视图        BUILD IMMEDIATE  --在视图编写好后创建        REFRESH FAST WITH PRIMARY KEY  --根据主表主键增量刷新(FAST,增量)        ON DEMAND  -- 在用户需要时,由用户刷新        ENABLE QUERY REWRITE  --可读写        AS        SELECT * FROM GG_ZLX_ZHU@TO_CPEES; --查询语句

    

       4、视图刷新

       根据业务需要,每月不定时刷新,所以不能是JOB,而且数量多,所以也不能一个一个刷新。根据以上条件,选择使用ORACLE自带工具DBMS_MVIEW工具包中REFRESH方法对物化视图进行刷新。该方法有两个参数,第一个参数是需要刷新的物化视图名称,第二个参数是刷新方式。我们可以写存储过来,对每个物化视图调用一次REFRESH方法,也可以使用“,”把物化视图连接以来,一次刷新。如下:

 

        CREATE OR REPLACE PROCDURE P_MVIEW_REFRESH AS

        BEGIN

             DBMS_MVIEW.REFRESH(‘GG_ZLX_ZHU‘,‘f‘);

        END P_MVIEW_REFRESH;

 

        或者使用

        CREATE OR REPLACE PROCDURE P_MVIEW_REFRESH AS

 

 

        BEGIN

             DBMS_MVIEW.REFRESH(‘GG_ZLX_ZHU,GG_ZLX_FU‘,‘ff‘);

        END P_MVIEW_REFRESH;

        注意:

        1、如果需要同时刷新多个物化视图,必须用逗号把各个物化视图名称连接起来,并对

        每个视图都要指明刷新方式(f、增量刷新,c、完全刷新,?、强制刷新)。

        2、当日志和物化视图创建好后,删除日志,则需要重新创建物化视图,否则无法增量

        刷新。

        3、因为上面写的物化视图时根据主键进行更新,因此,主表必须有主键。

        4、以上文章中红色是为可替换的,大家可以根据自己项目需求来修改。

 

 

希望上面的内容对大家能有帮助。

 

 

        忘了写删除方法了,日志和物化视图要分开删除

        DROP MATERIALIZED VIEW LOG ON GG_ZLX_ZHU@TOCPEES;

        DROP MATERIALIZED VIEW GG_ZLX_ZHU;

oracle 物化视图

标签:同步   mysql   get   acl   target   drop   系统   sql   需求   

人气教程排行