1。如果要创建基表是其它用户表的实体化视图,那么需要给实体化视图的owner赋予以下权限: grant create any materialized view to username; grant select any table to username; 如果要创建refresh on commit的视图,那么还需要下面这个权限: grant on commit refresh to username;
2。创建refresh on commit的语法如下,此类实体化视图在基表的事务commit之后,就会立刻刷新 create materialized view mv_t1 refresh fast on commit with primary key as select * from kamus.t1;
4。指定了start with ... next ...选项之后,第一次创建会有作一次完整刷新,然后在指定的时间间隔之后会定时刷新,本例中刷新间隔为1分钟。 语法如下: create materialized view mv_t1 refresh fast start with sysdate next sysdate+1/24/60 with primary key as select * from kamus.t1; 检查user_refresh视图和user_jobs视图,我们可以发现start with... next ...语法也就是oracle自动创建了一个刷新组,这个刷新组的名称跟实体化视图名称相同,并且implicit_destroy属性为y,表示只要该组中的实体化视图删除该组也自动被删除。同时,创建了一个job,job中的waht属性是dbms_refresh.refresh('"scott"."mv_t1"'); 自然,由于自动刷新是通过job完成的,那么初始化参数job_queue_processes必须大于0,这样job才会正常运行。