预览加载中,请您耐心等待几秒...
1/10
2/10
3/10
4/10
5/10
6/10
7/10
8/10
9/10
10/10

亲,该文档总共19页,到这已经超出免费预览范围,如果喜欢就直接下载吧~

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

Oracle的物化视图 一、------------------------------------------------------------------------------------------ 物化视图是包括一个查询结果的数据库对像,它是远程数据的的本地副本,或者用来生成基于数据表求和的汇总表。物化视图存储基于远程表的数据,也可以称为快照。 物化视图可以查询表,视图和其它的物化视图。 通常情况下,物化视图被称为主表(在复制期间)或明细表(在数据仓库中)。 对于复制,物化视图允许你在本地维护远程数据的副本,这些副本是只读的。如果你想修改本地副本,必须用高级复制的功能。当你想从一个表或视图中抽取数据时,你可以用从物化视图中抽取。 对于数据仓库,创建的物化视图通常情况下是聚合视图,单一表聚合视图和连接视图。 本篇我们将会看到怎样创建物化视图并且讨论它的刷新选项。 在复制环境下,创建的物化视图通常情况下主键,rowid,和子查询视图。 1.主键物化视图: 下面的语法在远程数据库表emp上创建主键物化视图 SQL>CREATEMATERIALIZEDVIEWmv_emp_pk REFRESHFASTSTARTWITHSYSDATE NEXTSYSDATE+1/48 WITHPRIMARYKEY ASSELECT*FROMemp@remote_db; Materializedviewcreated. 注意:当用FAST选项创建物化视图,必须创建基于主表的视图日志,如下: SQL>CREATEMATERIALIZEDVIEWLOGONemp; Materializedviewlogcreated.2.Rowid物化视图 下面的语法在远程数据库表emp上创建Rowid物化视图 SQL>CREATEMATERIALIZEDVIEWmv_emp_rowid REFRESHWITHROWID ASSELECT*FROMemp@remote_db; Materializedviewlogcreated. 3.子查询物化视图 下面的语法在远程数据库表emp上创建基于emp和dept表的子查询物化视图 SQL>CREATEMATERIALIZEDVIEWmv_empdept ASSELECT*FROMemp@remote_dbe WHEREEXISTS(SELECT*FROMdept@remote_dbd WHEREe.dept_no=d.dept_no) Materializedviewlogcreated. REFRESH子句[refresh[fast|complete|force][ondemand|commit] [startwithdate][nextdate][with{primarykey|rowid}]] Refresh选项说明: a.oracle用刷新方法在物化视图中刷新数据. b.是基于主键还是基于rowid的物化视图 c.物化视图的刷新时间和间隔刷新时间 Refresh方法-FAST子句 增量刷新用物化视图日志(参照上面所述)来发送主表已经修改的数据行到物化视图中.如果指定REFRESHFAST子句,那么应该对主表创建物化视图日志 SQL>CREATEMATERIALIZEDVIEWLOGONemp;Materializedviewlogcreated. 对于增量刷新选项,如果在子查询中存在分析函数,则物化视图不起作用。 Refresh方法-COMPLETE子句 完全刷新重新生成整个视图,如果请求完全刷新,oracle会完成完全刷新即使增量刷新可用。 RefreshMethod–FORCE子句 当指定FORCE子句,如果增量刷新可用Oracle将完成增量刷新,否则将完成完全刷新,如果不指定刷新方法(FAST,COMPLETE,orFORCE),Force选项是默认选项 主键和ROWD子句 WITHPRIMARYKEY选项生成主键物化视图,也就是说物化视图是基于主表的主键,而不是ROWID(对应于ROWID子句).PRIMARYKEY是默认选项,为了生成PRIMARYKEY子句,应该在主表上定义主键,否则应该用基于ROWID的物化视图. 主键物化视图允许识别物化视图主表而不影响物化视图增量刷新的可用性。 Rowid物化视图只有一个单一的主表,不能包括下面任何一项: nDistinct或者聚合函数. nGroupby,子查询,连接和SET操作 刷新时间 STARTWITH子句通知数据库完成从主表到本地表第一次复制的时间,应该及时估计下一次运行的时间点,NEXT子句说明了刷新的间隔时间. SQL>C