42.oracle物化视图
写在前面
先大概列一下数据库表设计的常规流程、方案、要遵循的规则
- 根据业务切分设计表
- 逻辑分层(数据库分层)
- 数据库结构设计与拆分:
水平拆分(mysql分片)
oracle分区
物化视图
中间表
设计方案 - 优化结构设计:
建立普通索引
建立规则索引
建立复合索引
数据规则(添加你认为必要的扩展字段)
预留字段(用于关联其他业务的)
做一些合理的冗余
物化视图的概念
视图(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物化视图的更多相关文章
- ORACLE物化视图具体解释
一.物化的一般使用方法物化视图是一种特殊的物理表,"物化"(Materialized)视图是相对普通视图而言的.普通视图是虚拟表.应用的局限性大,不论什么对视图的查询.oracle ...
- Oracle 物化视图 说明
一. 物化视图概述 Oracle的物化视图是包括一个查询结果的数据库对像,它是远程数据的的本地副本,或者用来生成基于数据表求和的汇总表.物化视图存储基于远程表的数据,也可以称为快照. 物化视图可 ...
- [O]ORACLE物化视图的使用
用于数据复制的物化视图 物化视图的一个主要功能就是用于数据的复制,Oracle推出的高级复制功能分为两个部分,多主复制和物化视图复制.而物化视图复制就是利用了物化视图的功能. 物化视图复制包含只读物化 ...
- Oracle物化视图的创建及使用
oracle物化视图 一.oracle物化视图基本概念 物化视图首先需要创建物化视图日志, oracle依据用户创建的物化视图日志来创建物化视图日志表, 物化视图日志表的名称为mlog$_后面跟 ...
- ORACLE物化视图(物理视图)
百度文库 http://wenku.baidu.com/view/f78f55c68bd63186bcebbc4b.html ORACLE物化视图 一.------------------------ ...
- Oracle物化视图的创建及使用(一
Oracle物化视图的创建及使用 http://blog.csdn.net/tegwy/article/details/8935058 先看简单创建语句: create materialized ...
- Oracle物化视图的一般使用
普通视图和物化视图根本就不是一个东西,说区别都是硬拼到一起的,首先明白基本概念,普通视图是不存储任何数据的,他只有定义,在查询中是转换为对应的定义SQL去查询,而物化视图是将数据转换为一个表,实际存储 ...
- 解决oracle 物化视图刷新失败
oracle 物化视图刷新失败可能原因: 1.视图未建立物化视图日志 2.基表为授权给用户 1.物化视图语法 create materialized view [view_name] refresh ...
- oracle物化视图
物化视图是一种特殊的物理表,“物化”(Materialized)视图是相对普通视图而言的.普通视图是虚拟表,应用的局限性大,任何对视图的查询,Oracle都实际上转换为视图SQL语句的查询. 这样对整 ...
随机推荐
- static变量和static函数
在C语言编程中,static的一个作用是信息屏蔽! 比方说,你自己定义了一个文件 -- 该文件中有一系列的函数以及变量的声明和定义! 你希望该文件中的一些函数和变量只能被该文件中的函数使用,那么,你可 ...
- ubuntu账户密码正确但是登录不进去系统
ubuntu12.04管理员账户登录不了桌面,只能客人会话登录 求助!!ubuntu12.04管理员账户登录不了桌面,只能客人会话登录. ctrl+alt+f1 ,切换到tty1,输入管理员帐号和密码 ...
- 宽字符、多字节、unicode、utf-8、gbk编码转化
今天遇到一个编码的问题,困惑了我很长时间,所以就简要的的了解了一下常用的编码类型. 我们最常见的是assic编码,它是一种单字节编码,对多容纳256个字符. 我们在编程的时候经常遇到unicode,u ...
- curl传post数据流
- ToList和ToDataTable(其中也有反射的知识)
using System;using System.Collections.Generic;using System.Data;using System.Linq;using System.Refle ...
- SOAP与REST比较(转)
出处:http://xiaobaila.blog.163.com/blog/static/189705129201141965434571/ SOAP与REST比较 如今,Web开发者的可选技术相当之 ...
- UVa 10829 L-Gap Substrings (后缀数组+rmq)
题意:给定上一个串,问你多少种UVU这一种形式的串,其中U不为空并且V的长度给定了. 析:枚举 U 的长度L,那么U一定是经过 0 L 2L 3L .... 其中的一个,所以求两个长度反lcp,一个向 ...
- BZOJ 1503 郁闷的出纳员 (treap)
1503: [NOI2004]郁闷的出纳员 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 13370 Solved: 4808[Submit][Stat ...
- Jdom的简单操作
http://blog.csdn.net/heirenheiren/article/details/7354108 http://www.cnblogs.com/hoojo/archive/2011/ ...
- HDU1301&&POJ1251 Jungle Roads 2017-04-12 23:27 40人阅读 评论(0) 收藏
Jungle Roads Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 25993 Accepted: 12181 De ...