预览加载中,请您耐心等待几秒...
1/4
2/4
3/4
4/4

在线预览结束,喜欢就下载吧,查找使用更方便

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

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

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

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

Oracle物化视图语法 物化视图概述: Oracle的物化视图提供了强大的功能,可以用在不同的环境中。在不同的环境中,物化视图的作用也不相同。数据仓库中的物化视图主要用于预先计算并保存表连接或聚集等耗时较多的操作的结果,这样,在执行查询时,就可以避免进行这些耗时的操作,而从快速的得到结果。在数据仓库中,还经常使用查询重写(queryrewrite)机制,这样不需要修改原有的查询语句,Oracle会自动选择合适的物化视图进行查询,完全对应用透明。物化视图和表一样可以直接进行查询。物化视图可以基于分区表,物化视图本身也可以分区。除了在数据仓库中使用,物化视图还用于复制、移动计算等方面。物化视图在很多方面和索引很相似:使用物化视图的目的是为了提高查询性能;物化视图对应用透明,增加和删除物化视图不会影响应用程序中SQL语句的正确性和有效性;物化视图需要占用存储空间;当基表发生变化时,物化视图也应当刷新。 物化视图语法:creatematerializedviewmaterialized_view_namebuild[immediate|deferred] --1.创建方式refresh[complete|fast|force|never] --2.物化视图刷新方式on[commit|demand] --3.刷新触发方式startwith(start_date) --4.开始时间next(interval_date) --5.间隔时间with[primarykey|rowid] --默认primarykey ENABLEQUERYREWRITE --7.是否启用查询重写as --8.关键字selectstatement; --9.基表选取数据的select语句 1.创建方式默认是immediate,立即;deferred,延迟,至第一次refresh时,才生效。2.物化视图刷新方式默认为force,意思是:如果可以快速刷新,就执行快速刷新;否则,执行完全刷新。complete,完全刷新,即,刷新时更新全部数据,包括视图中已经生成的原有数据。fast,快速刷新,只刷新增量部分。前提是,需要在基表上创建物化视图日志(见示例)。该日志记录基表数据变化情况,所以才能实现增量刷新。never,从不刷新。3.oncommit,基表有commit动作时,刷新视图,不能跨库执行(因为不知道别的库的提交动作);ondemand,在需要时刷新,即,根据后面设定的起始时间和时间间隔进行刷新,或者,手动调用dbms_mview包中的过程刷新时再执行刷新。4和5.即开始刷新时间和下次刷新的时间间隔。如:startwithsysdatenextsysdate+1/1440表示马上开始,刷新间隔为1分钟。(与oncommit选项冲突)6.基于基表的主键或者rowid创建。如果是基于rowid,不能对基表执行分组函数、多表连结等需要把多个rowid合成一行的操作(理由很简单:到底以哪个rowid为准呢?)。7.如果设置了初始化参数query_rewrite_enabled=true则默认就会启用查询重写。但是,数据库默认该参数为false。并且,不是什么时候都应该启用查询重写。所以,该参数应该设置为false,而在创建特定物化视图时,根据需要开启该功能。另外,如果选择使用了上面第4‘5选项,则不支持查询重写功能(原因很简单,所谓重写,就是将对基表的查询定位到了物化视图上,而4、5选项会造成物化视图上部分数据延迟,所以,不能重写)。 创建物化试图主要选项说明 创建物化视图时可以指定多种选项,下面对几种主要的选项进行简单说明: 名称BuildClause创建方式描述包括BUILDIMMEDIATE和BUILDDEFERRED两种取值BUILDIMMEDIATE在创建物化视图的时候就生成数据BUILDDEFERRED在创建时不生成数据,以后根据需要在生成数据默认BUILDIMMEDIATE 名称Refresh刷新子句描述当基表发生了DML操作后,物化视图何时采用哪种方式和基表进行同步语法[refresh[fast|complete|force] [ondemand|commit] [startwithdate] [nextdate] [with{primarykey|rowid}] ]简介FAST采用增量刷新,只刷新自上次刷新以后进行的修改;对于增量刷新选项,如果在子查询中存在分析函数,则物化视图不起作用。COMPLETE对整个物化视图进行完全的刷新即完全刷新重新生成整个视图FORCE(默认)Oracle在刷新时会去判断是否可以进行快速刷新,如果可以则采用Fast方式,否则采用Comp