博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
oracle
阅读量:4940 次
发布时间:2019-06-11

本文共 1793 字,大约阅读时间需要 5 分钟。

oracle物化视图创建全过程(转)

我们如果遇到需要从其它系统的数据库中取数据进行统计分析的问题,可疑选择使用的ODI工具进行抽数,但是对方提供的数据库用户下没有任何对象,只是有查询所有表的权限,因此无法做数据反向。

于是决定使用物化视图,把对方数据库中的数据拿过来,虽然数据量比较大,但是每月只拿一次,而且如果设置成增量更新,也不会太慢。现在记录下物化视图的创建过程(以一张表为例)。

一、准备条件以及备注

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

二、开始干活

1、首先要创建DB_LINK

  1. CREATE DATABASE LINK to_cpees  
  2.  
  3. CONNECT TO "username" identified by "password"  
  4.  
  5. using "CPEES"  

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

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

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

  1. CREATE MATERIALIZED VIEW LOG ON GG_ZLX_ZHU  
  2.  
  3. WITH PRIMARY KEY  
  4.  
  5. INCLUDING NEW VALUES;  
  6.  

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

3、创建Oracle物化视图

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

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

4、视图刷新

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

  1. CREATE OR REPLACE PROCDURE P_MVIEW_REFRESH AS  
  2.  
  3. BEGIN  
  4.  
  5. DBMS_MVIEW.REFRESH('GG_ZLX_ZHU','f');  
  6.  
  7. END P_MVIEW_REFRESH;  
  8.  

或者使用

  1. CREATE OR REPLACE PROCDURE P_MVIEW_REFRESH AS  
  2.  
  3. BEGIN  
  4.  
  5. DBMS_MVIEW.REFRESH('GG_ZLX_ZHU,GG_ZLX_FU','ff');  
  6.  
  7. END P_MVIEW_REFRESH;  
  8.  

注意:

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

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

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

刷新。

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

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

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

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

  1. DROP MATERIALIZED VIEW LOG ON GG_ZLX_ZHU@TOCPEES;  
  2.  
  3. DROP MATERIALIZED VIEW GG_ZLX_ZHU;  

转载于:https://www.cnblogs.com/fengtong/archive/2012/04/09/2439536.html

你可能感兴趣的文章
敏捷外包工程系列之三:固定合同(敏捷外包工程,敏捷开发,产品负责人,客户价值)...
查看>>
敏捷外包工程系列之二:人员结构(敏捷外包工程,敏捷开发,产品负责人,客户价值)...
查看>>
周鸿祎谈乔布斯(张亮)
查看>>
IT职场人生系列之三:第一份工作
查看>>
IT职场人生系列之四:怎样写简历
查看>>
asp.net中Roles和User的异常处理机制的思考
查看>>
IT职场人生系列之六:员工的公司观
查看>>
IT职场人生系列之七:学外语
查看>>
Rap框架练习
查看>>
补充“为什么Scrum不行”
查看>>
IT职场人生系列之八:行业与公司类型
查看>>
敏捷开发生态系统系列之一:序言及需求管理生态(客户价值导向-可工作软件-响应变化)...
查看>>
敏捷开发生态系统系列之二:敏捷生态系统-计划跟踪 I(跨职能团队-共同估算-每日立会-同行压力)...
查看>>
MVC的Controller-Action布局:单独的创建/编辑页面还是创建/编辑/查看一体的页面?...
查看>>
RAP框架练习(续)
查看>>
敏捷开发生态系统系列之三:计划跟踪II(需求优先级排序-迭代期内无变更-团队承诺)...
查看>>
当程序员,你应该懂的法则
查看>>
面试—每日一题(8)
查看>>
asp.net怎样在URL中使用中文、空格、特殊字符
查看>>
敏捷开发生态系统系列之四:计划跟踪II(自组织团队-开发团队自己估算-PO挑战估算-同行压力)...
查看>>