Oracle中建立定时刷新的物化视图

物化视图等价于数据的快照,可以使对视图的查询速度提升1个数量级以上,同时还可以在物化视图中建立索引,使查询速度进一步得以优化。

物化视图与数据的同步可设置为on commit和on demand,缺省为on demand。on commit可以在数据发生变化时及时更新数据,但对视图要求太多,包

含非主键join及稍微复杂一些的计算就无法使用,而且日志表配置稍有错误就会导致系统问题,风险颇高。

仅处于对历史数据查询的要求,可以考虑使用任务计划对视图进行完整更新,通过资源消耗换取实现的简易性和系统的稳定性。

建立完全更新的视图需要用户具有connect、resource和create materialized view权限,如果需要激活query rewrite,还需要授予global query

writer权限(或针对涉及的表单独授权)。以dba身份进行授权:

grant connect to test;
grant resource to test;
grant create materialized view to test;
grant global query rewrite to test;


建立测试用的基础表
create table person(id int primary key, name varchar(50), deptid int not null);
create table dept(id int primary key, name varchar(50));
插入测试数据
insert into person (id, name, deptid) values( 1, '用户1', 100);
insert into person (id, name, deptid) values( 1, '用户2', 101);
insert into dept (id, name) values( 100, '测试部门1');
insert into dept (id, name) values( 101, '测试部门2');

建立物化视图
create materialized view test_mview
refresh complete
start with sysdate
next sysdate + 1/1440
as
(
select p.id as pid, p.name as name, d.name as deptname
from person p, dept d
where
d.id = p.deptid
)

这里test_mview为物化视图的名字
refresh complete表示每次都删除掉所有记录重新生成
start with sysdate表示从当前执行时间开始执行数据记录生成
next定义下次执行时间
sysdate+1/1440表示当前执行时间之后1分钟进行下次更新(1440 = 24 x 60)
as 后的部分定义构成视图的sql

最好是自己手动创建以下,然后测试下结果比较实用

oracle在执行完更新后将重新计算当前时间和下次更新时间,因此以上的语法定义了一个每分钟更新一次的视图。

自动刷新是由oracle的任务计划执行,需要确认oracle中job_queue_processes的值大于0,否则将无法激活任务计划。

alter system set job_queue_processes=5;

你可能感兴趣的:(oracle)