oracle 物化视图(2)——物化视图语法!

create materialized view [view_name]
[tablespace tablespace_name]
[build immediate | build deferred | no prebuilt table]
refresh [fast | complete | force]
[
 on [commit | demand] 
 [with (paimary key | rowid)] 
 [enable  query rewrite | disable query rewrite] | 
 start with (start_time) next (next_time)
]
as
{创建物化视图用的查询语句}
以上是Oracle创建物化视图(Materialized View,以下简称MV)时的常用语法,各参数的含义如下:

创建方式(Build Methods):

build immediate:在创建物化视图的时候就生成数据,默认为BUILD IMMEDIATE。

build deferred:在创建时不生成数据,以后根据需要在生成数据。

no prebuilt table:将物化视图建立在一个已经存在的表上。这种情况下,物化视图和表必须同名。当删除物化视图时,不会删除同名的表。

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指定)就刷新一次;


查询重写(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。

物化视图日志:如果需要进行快速刷新,则需要建立物化视图日志。物化视图日志根据不同物化视图的快速刷新的需要,可以建立为ROWID或PRIMARY KEY类型的。还可以选择是否包括SEQUENCE、INCLUDING NEW VALUES以及指定列的列表。

例子:

SQL> select * from tab;

未选定行

SQL> create table t1 (a varchar2(10) primary key,b number(10));  --这里表有主键。

表已创建。

SQL> create materialized view log on t1 with primary key;  --注意这里的with primary key。

实体化视图日志已创建。

SQL> select * from tab;

TNAME                          TABTYPE  CLUSTERID
------------------------------ ------- ----------
MLOG$_T1                       TABLE             --可以看见多了两个日志表。
RUPD$_T1                       TABLE
T1                             TABLE

SQL> create materialized view v1 
  2  build immediate 
  3  refresh fast on commit               --增量刷新。
  4  with primary key                     --注意这里的with primary key。
  5  disable query rewrite 
  6  as select * from t1;

实体化视图已创建。

SQL> create table t2 (a varchar2(10),b number(10));         --这里表没有主键。

表已创建。

SQL> create materialized view log on t2 with rowid;         --注意这里的with rowid。

实体化视图日志已创建。

SQL> create materialized view v2
  2  build immediate 
  3  refresh fast on commit 
  4  with rowid                                   --注意这里的with rowid。
  5  disable query rewrite 
  6  as select * from t2;

实体化视图已创建。

SQL> create materialized view v3
  2  build immediate
  3  refresh force on demand 
  4  start with sysdate next sysdate + 1/24       --定时刷新的。
  5  disable query rewrite
  6  as select * from t1;

实体化视图已创建。
总结:

1、build immediate 和 disable query rewrite 都是默认的设置;

2、如果是refresh fast on commit方式创建,并且表上没有主键,那么创建日志和视图都必须使用with rowid方式,表上面有主键才可以使用with primary key;

3、refresh fast on commit方式不可以和start with sysdate next sysdate + 1/24方式一起使用。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值