1、Oracle物化视图语法性能
create materialized view [view_name]
refresh [fast|complete|force]
[
on [commit|demand] | start with (start_time) next (next_time)
]
as
{建立物化视图用的查询语句}ui
以上是Oracle建立物化视图(Materialized View, 如下简称MV)时经常使用的语法,各参数的含义以下:日志
一、refresh [fast|complete|force] 视图刷新的方式:
fast: 增量刷新.假设前一次刷新的时间为t1,那么使用fast模式刷新物化视图时,只向视图中添加t1到当前时间段内主表变化过的数据.为了记录这种变化,创建增量刷新物化视图还须要一个物化视图日志表。create materialized view log on 主表名。
complete: 所有刷新。至关于从新执行一次建立视图的查询语句。
force: 这是默认的数据刷新方式。当可使用fast模式时,数据刷新将采用fast方式;不然使用complete方式。索引
二、MV数据刷新的时间:
on demand:在用户须要刷新的时候刷新,这里就要求用户本身动手去刷新数据了(也可使用job定时刷新)
on commit:当主表中有数据提交的时候,当即刷新MV中的数据;
start ……:从指定的时间开始,每隔一段时间(由next指定)就刷新一次;同步
Oracle的物化视图提供了强大的功能,能够用于预先计算并保存表链接或汇集等耗时较多的操做的结果,这样,在执行查询时,就能够避免进行这些耗时的操做,而从快速的获得结果。物化视图有不少方面和索引很类似:使用物化视图的目的是为了提升查询性能;物化视图对应用透明,增长和删除物化视图不会影响应用程序中SQL语句的正确性和有效性;物化视图须要占用存储空间;当基表发生变化时,物化视图也应当刷新。it
物化视图能够分为如下三种类型:包含汇集的物化视图;只包含链接的物化视图;嵌套物化视图。三种物化视图的快速刷新的限制条件有很大区别,而对于其余方面则区别不大。建立物化视图时能够指定多种选项,下面对几种主要的选择进行简单说明:ast
一、建立方式(Build Methods):包括BUILD IMMEDIATE(当即)和BUILD DEFERRED(延迟)两种。BUILD IMMEDIATE是在建立物化视图的时候就生成数据,而BUILD DEFERRED则在建立时不生成数据,之后根据须要在生成数据。默认为BUILD IMMEDIATE。 rust
二、查询重写(Query Rewrite):包括ENABLE QUERY REWRITE和DISABLE QUERY REWRITE两种。分别指出建立的物化视图是否支持查询重写。查询重写是指当对物化视图的基表进行查询时,Oracle会自动判断可否经过查询物化视图来获得结果,若是能够,则避免了汇集或链接操做,而直接从已经计算好的物化视图中读取数据。默认为DISABLE QUERY REWRITE。语法
三、刷新(Refresh):指当基表发生了DML操做后,物化视图什么时候采用哪一种方式和基表进行同步。刷新的模式有两种:ON DEMAND和ON COMMIT。ON DEMAND指物化视图在用户须要的时候进行刷新,能够手工经过DBMS_MVIEW.REFRESH等方法来进行刷新,也能够经过JOB定时进行刷新。ON COMMIT指出物化视图在对基表的DML操做提交的同时进行刷新。刷新的方法有四种:FAST、COMPLETE、FORCE和NEVER。FAST刷新采用增量刷新,只刷新自上次刷新之后进行的修改。COMPLETE刷新对整个物化视图进行彻底的刷新。若是选择FORCE方式,则Oracle在刷新时会去判断是否能够进行快速刷新,若是能够则采用FAST方式,不然采用COMPLETE的方式。NEVER指物化视图不进行任何刷新。默认值是FORCE ON DEMAND。程序
在创建物化视图的时候能够指定ORDER BY语句,使生成的数据按照必定的顺序进行保存。不过这个语句不会写入物化视图的定义中,并且对之后的刷新也无效。
四、物化视图日志:若是须要进行快速刷新,则须要创建物化视图日志。物化视图日志根据不一样物化视图的快速刷新的须要,能够创建为ROWID或PRIMARY KEY类型的。还能够选择是否包括SEQUENCE、INCLUDING NEW VALUES以及指定列的列表。
能够指明ON PREBUILD TABLE语句将物化视图创建在一个已经存在的表上。这种状况下,物化视图和表必须同名。当删除物化视图时,不会删除同名的表。这种物化视图的查询重写要求参数QUERY_REWRITE_INTEGERITY必须设置为trusted或者stale_tolerated。
物化视图能够进行分区。并且基于分区的物化视图能够支持分区变化跟踪(PCT)。具备这种特性的物化视图,当基表进行了分区维护操做后,仍然能够进行快速刷新操做。对于汇集物化视图,能够在GROUP BY列表中使用CUBE或ROLLUP,来创建不一样等级的汇集物化视图。