当前位置:  数据库>oracle

Oracle物化视图创建实例

    来源: 互联网  发布时间:2017-03-25

    本文导语: 公司的项目中遇到需要从其它系统的数据库中取数据进行统计分析的问题,初步选择使用Oracle的ODI工具进行抽数,但是对方提供的数据库用户下没有任何对象,只是有查询所有表的权限,因此无法做数据反向。于是决定使用物化...

公司的项目中遇到需要从其它系统的数据库中取数据进行统计分析的问题,初步选择使用Oracle的ODI工具进行抽数,但是对方提供的数据库用户下没有任何对象,只是有查询所有表的权限,因此无法做数据反向。于是决定使用物化视图,把对方数据库中的数据拿过来,虽然数据量比较大,但是每月只拿一次,而且如果设置成增量更新,也不会太慢。现在记录下物化视图的创建过程(以一张表为例)。

一、准备条件以及备注

假设双方数据库都是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;


    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Linux上建立第二个ORACLE实例分析
  • Linux操作系统下Oracle数据库多实例启动方式及修改内存
  • oracle的存储过程实例讲解
  • linux redhat5.6安装oracle11g在自动创建实例时停住不动,有图
  • oracle分页存储过程 oracle存储过程实例
  • C#连接Oracle数据库的实例方法
  • Oracle数据库实例两则
  • Oracle 删除归档日志实例
  • Oracle 10g for solaris准备工作和实例的删除
  • Oracle 11G 无法连接到数据库实例故障排除
  • Linux下设置Oracle 10g 服务以及实例自动启动
  • oracle group by语句实例测试
  • oracle的存储过程实例讲解 iis7站长之家
  • Linux下删除Oracle实例
  • 与Oracle RAC相关的连接配置写法实例
  • Oracle监听器Server端与Client端配置实例
  • Oracle中使用触发器(trigger)和序列(sequence)模拟实现自增列实例
  • oracle删除已存在的表的实例
  • Aix 5.3下自动备份Oracle多个实例
  • Oracle数据库安全性管理基本措施实例解析
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle 10g和Oracle 11g网格技术介绍


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3