欢迎来到天天文库
浏览记录
ID:34724325
大小:61.41 KB
页数:10页
时间:2019-03-10
《materializedview基础知识》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、materializedview基础知识一、------------------------------------------------------------------------------------------物化视图是包括一个查询结果的数据库对像,它是远程数据的的本地副本,或者用来生成基于数据表求和的汇总表。物化视图存储基于远程表的数据,也可以称为快照。 物化视图可以查询表,视图和其它的物化视图。 通常情况下,物化视图被称为主表(在复制期间)或明细表(在数据仓库中)。 对于复制,物化视图允许你在
2、本地维护远程数据的副本,这些副本是只读的。如果你想修改本地副本,必须用高级复制的功能。当你想从一个表或视图中抽取数据时,你可以用从物化视图中抽取。 对于数据仓库,创建的物化视图通常情况下是聚合视图,单一表聚合视图和连接视图。本篇我们将会看到怎样创建物化视图并且讨论它的刷新选项。 在复制环境下,创建的物化视图通常情况下主键,rowid,和子查询视图。1.主键物化视图: 下面的语法在远程数据库表emp上创建主键物化视图 SQL>CREATEMATERIALIZEDVIEWmv_emp_p
3、k REFRESHFASTSTARTWITHSYSDATE NEXT SYSDATE+1/48 WITHPRIMARYKEY ASSELECT*FROMemp@remote_db; Materializedviewcreated. 注意:当用FAST
4、选项创建物化视图,必须创建基于主表的视图日志,如下: SQL>CREATEMATERIALIZEDVIEWLOGONemp; Materializedviewlogcreated.2.Rowid物化视图 下面的语法在远程数据库表emp上创建Rowid物化视图 SQL>CREATEMATERIALIZEDVIEWmv_emp_rowid REFRESHWITHROWID
5、 ASSELECT*FROMemp@remote_db; Materializedviewlogcreated.3.子查询物化视图 下面的语法在远程数据库表emp上创建基于emp和dept表的子查询物化视图 SQL>CREATEMATERIALIZEDVIEW mv_empdept ASSELECT*FROMemp@remote
6、_dbe WHEREEXISTS (SELECT*FROMdept@remote_dbd WHEREe.dept_no=d.dept_no) Materializedviewlogcreated. REFRESH子句[refresh[fast
7、complete
8、force] [ondemand
9、commit]
10、 [startwithdate][nextdate] [with{primarykey
11、rowid}]] Refresh选项说明:a. oracle用刷新方法在物化视图中刷新数据.b. 是基于主键还是基于rowid的物化视图c. 物化视图的刷新时间和间隔刷新时间 Refresh方法-FAST子句 增量刷新用物化视图日志(参照上面所述)来发送主表已经修改的数据行到物化视图中.如果指定REFRESHFAST子句,那么应该对主表创建物化视图日志
12、 SQL>CREATEMATERIALIZEDVIEWLOGONemp;Materializedviewlogcreated. 对于增量刷新选项,如果在子查
此文档下载收益归作者所有