Oracle物化视图

  之前我们接触过的视图view,是基于基表数据生成的数据,这个视图表不会不占据数据磁盘空间,也就是逻辑表。使用这种视图只是简化你每次书写sql语句的代码量,在数据库性能方面没有起到任何作用。

  而物化视图material view 呢,它就是个物理表,占据数据磁盘空间,只是这个表的数据可以通过其他表查询出来。下面看一下创建物化视图的语法:

 create materialized view view_name
  refresh [fast|complete|force]
  [
    on [commit|demand] |
    start with (start_time) next (next_time)

  ]
  AS subquery;

  (1)视图数据生成时间有两种:不指定,默认开启 build immediate

    build immediate 是在创建物化视图的时候生成数据。

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

  (2)视图刷新模式有两种:不指定,默认开启 on demand

    on demand 仅该物化视图需要被刷新的时候才刷新。

    on commit 一旦基表有数据更新,基表提交事务的时候立即刷新。

  (3)视图刷新方法有三种:

    complete(完全刷新):会删除表中的所有的记录,然后根据物化视图中查询语句的定义重新生成物化视图。

    fast(快速刷新):采用增量刷新的方法。

    force:这是oracle默认的刷新方式。Oracle会自动判断是否满足快速刷新的条件,如果满足则进行快速刷新,否则进行完全刷新。

  (4)案例:

create materialized view my_material refresh force on demand start with sysdate next
to_date(concat(to_char(sysdate+1,'dd-mm-yyyy'),'10:25:00'),'dd-mm-yyyy hh24:mi:ss') as
select * from user_info; --每天10点25刷新

  总结:物化视图类似于中间表,当查询某个业务需要联合多个表进行查询的时候,且需要消耗很长时间,大家都知道使用join等联合查询,是非常消耗性能,尤其当每个表中的数据量非常大的时候。这个时候可以考虑使用物化视图,定时更新数据,下次直接查询物化视图即可。

posted @ 2017-06-05 15:44  gdpuzxs  阅读(767)  评论(0编辑  收藏  举报