创建实体化视图的几个注意点

<script type="text/javascript"> </script> <script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
<script type="text/javascript"> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>

1。如果要创建基表是其它用户表的实体化视图,那么需要给实体化视图的owner赋予以下权限:
grantCREATEANYMATERIALIZEDVIEWtousername;
grantSELECTANYTABLEtousername;
如果要创建refreshoncommit的视图,那么还需要下面这个权限:
grantONCOMMITREFRESHtousername;

2。创建refreshoncommit的语法如下,此类实体化视图在基表的事务commit之后,就会立刻刷新
CREATEMATERIALIZEDVIEWMV_T1
REFRESHFASTONCOMMITWITHPRIMARYKEYASSELECT*FROMkamus.t1;

3。如果不指定oncommit,那么默认是ondemand,只有手工调用DBMS_MVIEW包中的刷新过程,实体化视图才会被刷新

4。指定了startwith...next...选项之后,第一次创建会有作一次完整刷新,然后在指定的时间间隔之后会定时刷新,本例中刷新间隔为1分钟。
语法如下:
CREATEMATERIALIZEDVIEWMV_T1
REFRESHFASTSTARTWITHSYSDATENEXTsysdate+1/24/60WITHPRIMARYKEYASSELECT*FROMkamus.t1;
检查USER_REFRESH视图和USER_JOBS视图,我们可以发现startwith...next...语法也就是自动创建了一个刷新组,这个刷新组的名称跟实体化视图名称相同,并且IMPLICIT_DESTROY属性为Y,表示只要该组中的实体化视图删除该组也自动被删除。同时,创建了一个JOB,JOB中的waht属性是dbms_refresh.refresh('"SCOTT"."MV_T1"');
自然,由于自动刷新是通过JOB完成的,那么初始化参数job_queue_processes必须大于0,这样JOB才会正常运行。

5。可以自己创建刷新组来定时刷新,我以前的这篇文章中有创建刷新组的方法:
http://blog.csdn.net/kamus/archive/2004/09/18/108496.aspx
<script type="text/javascript"> </script> <script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
<script type="text/javascript"> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值