- 浏览: 636263 次
- 性别:
- 来自: 上海
文章分类
- 全部博客 (213)
- JAVA (53)
- Tomcat (14)
- EXTJS专栏 (2)
- 数据库 (23)
- JavaScript (13)
- jQuery (11)
- 需求分析 (2)
- css (1)
- 手机 (1)
- php (7)
- 生活 (1)
- ssh (11)
- JFReeChart (2)
- Delphi (1)
- junit (0)
- liunx (10)
- 项目管理 (11)
- 文件下载 (1)
- Eclipse (2)
- jsp (2)
- 外挂、游戏 (1)
- 面试题 (8)
- 性能测试 (2)
- apache (1)
- MyBatis (1)
- Webservice (2)
- ant (1)
- IDEA (2)
- log4j (1)
- 小程序 (1)
最新评论
-
hll127:
请问service这个方法里为什么要while(true)啊? ...
jsp页面静态化例子 -
tarena1:
Spring 源码解读 推荐流程 -
konglx:
springaop_springmvc 写道可以参考最新的文档 ...
Web项目添加Maven支持步骤 -
springaop_springmvc:
可以参考最新的文档:如何在eclipse jee中检出项目并转 ...
Web项目添加Maven支持步骤 -
9976:
很好,谢谢
Spring 源码解读 推荐流程
物化视图是包括一个查询结果的数据库对像,它是远程数据的的本地副本,或者用来生成基于数据表求和的汇总表。物化视图存储基于远程表的数据,也可以称为快照。
物化视图可以查询表,视图和其它的物化视图。
通常情况下,物化视图被称为主表(在复制期间)或明细表(在数据仓库中)。
对于复制,物化视图允许你在本地维护远程数据的副本,这些副本是只读的。如果你想修改本地副本,必须用高级复制的功能。当你想从一个表或视图中抽取数据时,你可以用从物化视图中抽取。
对于数据仓库,创建的物化视图通常情况下是聚合视图,单一表聚合视图和连接视图。
本篇我们将会看到怎样创建物化视图并且讨论它的刷新选项。
在复制环境下,创建的物化视图通常情况下主键,rowid,和子查询视图。
1.主键物化视图:
下面的语法在远程数据库表emp上创建主键物化视图
SQL> CREATE MATERIALIZED VIEW mv_emp_pk
REFRESH FAST START WITH SYSDATE
NEXT SYSDATE + 1/48
WITH PRIMARY KEY
AS SELECT * FROM emp@remote_db;
Materialized view created.
注意:当用FAST选项创建物化视图,必须创建基于主表的视图日志,如下:
SQL> CREATE MATERIALIZED VIEW LOG ON emp;
Materialized view log created.
2.Rowid物化视图
下面的语法在远程数据库表emp上创建Rowid物化视图
SQL> CREATE MATERIALIZED VIEW mv_emp_rowid
REFRESH WITH ROWID
AS SELECT * FROM emp@remote_db;
Materialized view log created.
3.子查询物化视图
下面的语法在远程数据库表emp上创建基于emp和dept表的子查询物化视图
SQL> CREATE MATERIALIZED VIEW mv_empdept
AS SELECT * FROM emp@remote_db e
WHERE EXISTS
(SELECT * FROM dept@remote_db d
WHERE e.dept_no = d.dept_no)
Materialized view log created.
REFRESH 子句
[refresh [fast|complete|force]
[on demand | commit]
[start with date] [next date]
[with {primary key|rowid}]]
Refresh选项说明:
a. oracle用刷新方法在物化视图中刷新数据.
b. 是基于主键还是基于rowid的物化视图
c. 物化视图的刷新时间和间隔刷新时间
Refresh方法-FAST子句
增量刷新用物化视图日志(参照上面所述)来发送主表已经修改的数据行到物化视图中.如果指定REFRESH FAST子句,那么应该对主表创建物化视图日志
SQL> CREATE MATERIALIZED VIEW LOG ON emp;
Materialized view log created.
对于增量刷新选项,如果在子查询中存在分析函数,则物化视图不起作用。
Refresh方法- COMPLETE子句
完全刷新重新生成整个视图,如果请求完全刷新,oracle会完成 完全刷新即使增量刷新可用。
Refresh Method – FORCE 子句
当指定FORCE子句,如果增量刷新可用Oracle将完成增量刷新,否则将完成完全刷新,如果不指定刷新方法(FAST, COMPLETE, or FORCE),Force选项是默认选项
主键和ROWD子句
WITH PRIMARY KEY选项生成主键物化视图,也就是说物化视图是基于主表的主键,而不是ROWID(对应于ROWID子句). PRIMARY KEY是默认选项,为了生成PRIMARY KEY子句,应该在主表上定义主键,否则应该用基于ROWID的物化视图.
主键物化视图允许识别物化视图主表而不影响物化视图增量刷新的可用性。
Rowid物化视图只有一个单一的主表,不能包括下面任何一项:
n Distinct 或者聚合函数.
n Group by,子查询,连接和SET操作
刷新时间
START WITH子句通知数据库完成从主表到本地表第一次复制的时间,应该及时估计下一次运行的时间点, NEXT 子句说明了刷新的间隔时间.
SQL> CREATE MATERIALIZED VIEW mv_emp_pk
REFRESH FAST
START WITH SYSDATE
NEXT SYSDATE + 2
WITH PRIMARY KEY
AS SELECT * FROM emp@remote_db;
Materialized view created.
在上面的例子中,物化视图数据的第一个副本在创建时生成,以后每两天刷新一次.
总结
物化视图提供了可伸缩的基于主键或ROWID的视图,指定了刷新方法和自动刷新的时间。
发表评论
-
ORACLE 索引原理
2013-03-25 21:40 1090B-TREE索引 一个B树索引只有一个根节点,它实际就 ... -
oracle笔记1-序列
2012-12-14 10:08 900建立sequence时注意:Cache Size 至少要设置为 ... -
in与exist , not in与not exist 的区别
2011-12-19 11:31 1057in和exists in 是把外表和 ... -
数据库性能调优技术—深入理解单表执行计划
2011-12-18 12:15 1380一、概述 这篇文章是数据库性能调优技术的第二篇。上 ... -
Oracle SQL性能优化
2011-12-17 20:38 828(1) 选择最有效率的表名顺序(只在基于规则的优化器 ... -
SQL Server 2005 Express 远程连接 客户端 远程访问 设置 全攻略 (适用 SQL Server 2005 其他版本)
2011-05-01 12:12 2759SQL Server 2005 Express 是微软提供的数 ... -
行级触发器对当前表操作,”ORA-04091: 表 COMPANY 发生了变化, 触发器/函数不能读它“,解决方法
2011-03-07 15:12 4548行级触发器对当前表操作,”ORA-04091: 表 ... -
启动mssql远程TCP/IP访问权限
2011-01-03 21:17 1352如果想mssql能通过远程访问或是myeclipse能访问,需 ... -
oracle替换clob类型中的一段数据
2010-11-02 11:35 1982CREATE OR REPLACE FUNCTION dfn_ ... -
Sql 批量替换所有表中内容
2010-11-02 09:30 1113declare @t varchar(255),@c varc ... -
删除所有表中数据
2010-11-02 09:28 1179最近一个项目中作结合测试,需要测试数据流的正确性,这就需要在执 ... -
Ms Sql SErver 2000和2005数据互导
2010-08-20 22:26 1628因为数据库附加到2005的时候, 数据库文件已经自动升级到20 ... -
某个数据文件损坏,如何打开数据库?
2010-04-19 11:05 1540某个数据文件损坏,如何打开数据库? 系统环境: 1、 ... -
增大oracle重做日志的大小
2010-03-26 21:09 4558重做日志(redo log)是由LGWR来进行控制的。Orac ... -
MySQL外键
2010-02-27 11:26 1073定义数据表 假如某个电脑生产商,它的数据库中保存着整机和 ... -
mysql乱码解决
2010-01-23 14:45 873在mysql的my.ini文件中增加以下配置: 1、 [m ... -
如何查看oracle表空间
2009-11-14 11:01 2951select tablespace_name,sum(byte ... -
ORA-04031: 无法分配 12519000 字节的共享内存 ("large pool","unknown object","hash-join subh"
2009-10-20 16:51 8643ORA-04031: 无法分配 12519000 字节的共享内 ... -
我整理的关于P4安装ORACLE解决方法
2009-08-18 11:35 1593我整理的关于P4安装ORACLE解决方法 P4的计算机最好安 ... -
创建用户
2009-06-23 22:26 1172/*--示例说明 示例在数据库pubs中创建一个 ...
相关推荐
Oracle中物化视图的使用.pdf
物化视图 (MV)在一个段中存储查询结果,并且能够在提交查询时将结果返回给用户,从而不再需要重新执行查询 — 在查询要执行几次时,这是一个很大的好处。物化视图可以利用一个快速刷新机制从基础表中全部或增量刷新...
ORACLE9I物化视图
Oracle中物化视图很重要,物化视图优秀论文. 在数据仓库中物化视图是非常重要的。Oracle中物化视图很重要,物化视图优秀论文. 在数据仓库中物化视图是非常重要的。Oracle中物化视图很重要,物化视图优秀论文. 在数据...
ORACLE使用物化视图和查询重写功能
Oracle物化视图应用详,有实例和各属性介绍
Oracle物化视图创建和使用,设置物化视图的自动刷新时间
里面详细讲述物化视图的种种创建,物化日志的结构,group by 语句创建物化视图的处理
Oracle怎么根据物化视图日志快速刷新物化视图
Oracle物化视图使用[文].pdf
物化视图学习笔记 错误问题分析总结 详细讲解了物化视图的内部构造,从零基础开始学习 重点说明ORA-12034的错误解决方案
Oracle物化视图增量刷新的应用研究.pdf
orace表分区及物化视图 进一步了解oracle表分区技术及物化视图技术应用
利用ORACLE物化视图建立报表数据库.pdf
物化视图是包括一个查询结果的数据库对像,它是远程数据的的本地副本,或者用来生成基于数据表求和的汇总表。物化视图存储基于远程表的数据,也可以称为快照。
物化视图的种类介绍和各种创建方式,刷新方式
oracle物化视图资料,表明物化视图的创建等
ORACLE 中的物化视图在大量的报表查询中使用平凡,本文介绍了物化视图的原理和使用方法,觉得不错。