写在前面

  先大概列一下数据库表设计的常规流程、方案、要遵循的规则

  1. 根据业务切分设计表
  2. 逻辑分层(数据库分层)
  3. 数据库结构设计与拆分:
    水平拆分(mysql分片)
    oracle分区
    物化视图
    中间表
    设计方案
  4. 优化结构设计:
    建立普通索引
    建立规则索引
    建立复合索引
    数据规则(添加你认为必要的扩展字段)
    预留字段(用于关联其他业务的)
    做一些合理的冗余

物化视图的概念

  视图(VIEW)是一种虚表,其目的仅仅是为了方便我们进行综合数据查询,它并不能提高性能。想要提高性能的话,就需要引出物化视图了。

  物化视图是一种特殊的物理表,物化(materialized)视图是相对普通视图而言的。

  物化视图的特点:

  • 是一个物理表而且不仅仅是一个物理表,可以查询user_tables看一下。
  • 物化视图是一种段(segment),有自己的物理存储属性。
  • 物化视图会占用数据库磁盘空间,可以查询user_segment看一下。

  物化视图刷新类型:手工刷新和自动刷新,默认为手工刷新。(ON DEMAND、ON COMMIT)

  二者的区别在于刷新的方法不同,ON DEMAND,仅在该物化视图“需要”被刷新才会刷新,就是更新物化视图,以保证表和视图的一致性;ON COMMIT是一旦表有COMMIT(事务提交),则立即刷新,更新物化视图。

物化视图的使用

create materialized view mv_name[选项N] as select * from table_name;

  • 选项1:BUILD[IMMEDIATE,DEFFERRED]是否在创建视图是生成数据,默认生成;defferred 需要的时候生成。
  • 选项2:REFRESH[FAST , COMPLETE , FORCE , NEVER],fast是增量属性,或者说叫快速刷新;complete 全表刷新;force 如果增量刷新可以使用则使用增量刷新,否则全表刷新;never表示不刷新。
  • 选项3:ON[DEMAND , COMMIT] 即手工刷新和提交时刷新。
  • 选项4:START WITH:通知数据库完成从主表到本地表第一次复制的时间。
  • 选项5:NEXT :刷新的时间间隔。

准备

用dba角色给scott分配创建物化视图的权限

创建简单物化视图

来更新一下看看物化视图有没有变:

结果显然可见,没有变,为什么呢?因为update后没有commit; commit后视图数据发生了变化。

配置为增量刷新

前面在创构建物化视图的时候,refresh被指定为force,但就目前来看,用的并不是增量刷新,而是全表刷新。因为物化视图并不知道基表在修改的时候更新了哪一条数据,所以要明确指定出来:

create materialized view log on a with rowid;

create materialized view log on b with rowid;

再创建一个物化视图,注意一点要AROWID和BROWID:

指定手动刷新,每隔一分钟刷一次。

create materialized view mv_ab
    refresh fast on demand
    start with sysdate
    next sysdate+1/1440
as
    select a.rowid as arowid , b.rowid as browid,a.id, a.name, b.clsid, b.name as clsname
    from a,b
    where a.clsid = b.clsid;

42.oracle物化视图的更多相关文章

  1. ORACLE物化视图具体解释

    一.物化的一般使用方法物化视图是一种特殊的物理表,"物化"(Materialized)视图是相对普通视图而言的.普通视图是虚拟表.应用的局限性大,不论什么对视图的查询.oracle ...

  2. Oracle 物化视图 说明

    一.    物化视图概述 Oracle的物化视图是包括一个查询结果的数据库对像,它是远程数据的的本地副本,或者用来生成基于数据表求和的汇总表.物化视图存储基于远程表的数据,也可以称为快照. 物化视图可 ...

  3. [O]ORACLE物化视图的使用

    用于数据复制的物化视图 物化视图的一个主要功能就是用于数据的复制,Oracle推出的高级复制功能分为两个部分,多主复制和物化视图复制.而物化视图复制就是利用了物化视图的功能. 物化视图复制包含只读物化 ...

  4. Oracle物化视图的创建及使用

    oracle物化视图 一.oracle物化视图基本概念  物化视图首先需要创建物化视图日志,  oracle依据用户创建的物化视图日志来创建物化视图日志表,  物化视图日志表的名称为mlog$_后面跟 ...

  5. ORACLE物化视图(物理视图)

    百度文库 http://wenku.baidu.com/view/f78f55c68bd63186bcebbc4b.html ORACLE物化视图 一.------------------------ ...

  6. Oracle物化视图的创建及使用(一

    Oracle物化视图的创建及使用 http://blog.csdn.net/tegwy/article/details/8935058 先看简单创建语句: create   materialized  ...

  7. Oracle物化视图的一般使用

    普通视图和物化视图根本就不是一个东西,说区别都是硬拼到一起的,首先明白基本概念,普通视图是不存储任何数据的,他只有定义,在查询中是转换为对应的定义SQL去查询,而物化视图是将数据转换为一个表,实际存储 ...

  8. 解决oracle 物化视图刷新失败

    oracle 物化视图刷新失败可能原因: 1.视图未建立物化视图日志 2.基表为授权给用户 1.物化视图语法 create materialized view [view_name] refresh ...

  9. oracle物化视图

    物化视图是一种特殊的物理表,“物化”(Materialized)视图是相对普通视图而言的.普通视图是虚拟表,应用的局限性大,任何对视图的查询,Oracle都实际上转换为视图SQL语句的查询. 这样对整 ...

随机推荐

  1. Vue.js基础知识

    <!DOCTYPE html> <html lang="en" xmlns:v-bind="http://www.w3.org/1999/xhtml&q ...

  2. sort_contours_xld算子的几种排序方式研究

    算子sort_contours_xld算子有5种排序方式,即: 'upper_left': The position is determined by the upper left corner of ...

  3. [转].NET 4.5+项目迁移.NET Core的问题记录 HTTP Error 502.5

    本文转自:http://www.cnblogs.com/ronli/p/5900001.html 这几天试着把目前的开发框架迁移到新的.net core平台,中间遇到的问题在这里简单记录一下. 迁移过 ...

  4. Linux select/poll和epoll实现机制对比

    关于这个话题,网上已经介绍的比较多,这里只是以流程图形式做一个简单明了的对比,方便区分. 一.select/poll实现机制 特点: 1.select/poll每次都需要重复传递全部的监听fd进来,涉 ...

  5. PKUWC2019 真·游记

    由于我这个大傻逼考试结果实在是没法看,所以这篇游记将尽可能略去和考试有关的内容,变成一篇真正的游记…… 接下来的内容中将会出现各种旅游攻略,寻求干货的同学可以提前左转了. Day -7 学考终于结束了 ...

  6. xml数据改动

    public void reXml ( string namepngname ) { XmlDocument doc = new XmlDocument(); doc.Load(_xmlpath); ...

  7. SQL group by 分组后,同一组的排序后取第一条

    SELECT * FROM(                SELECT                     [SPID]                    ,[PH1]           ...

  8. 16 Finding a Protein Motif

    Problem To allow for the presence of its varying forms, a protein motif is represented by a shorthan ...

  9. K8s基于DNS的服务发现(转)

    原文地址:https://www.oschina.net/question/2657833_2201246 1.Kubernetes中如何发现服务 ◆   发现Pod提供的服务 首先使用nginx-d ...

  10. HRBUST1311 火影忍者之~忍者村 2017-03-06 16:06 106人阅读 评论(0) 收藏

    火影忍者之-忍者村   忍者村是忍者聚居的村子,相等于国家的军事力量.绝大部分村民都是忍者,有一些忍者会在村内开设书店.餐厅等,不过大部分忍者都是为村子执行任务的忍者,以赚取酬劳,并于战时为国家出战. ...