zoukankan      html  css  js  c++  java
  • oracle物化视图

    物化视图是一种特殊的物理表,“物化”(Materialized)视图是相对普通视图而言的。普通视图是虚拟表,应用的局限性大,任何对视图的查询,Oracle都实际上转换为视图SQL语句的查询。

    这样对整体查询性能的提高,并没有实质上的好处。

    物化视图的类型:ON DEMAND、ON COMMIT

        二者的区别在于刷新方法的不同,ON DEMAND顾名思义,仅在该物化视图“需要”被刷新了,才进行刷新(REFRESH),即更新物化视图,以保证和基表数据的一致性;

     而ON COMMIT是说,一旦基表有了COMMIT,即事务提交,则立刻刷新,立刻更新物化视图,使得数据和基表一致。

      ON DEMAND物化视图的特性及其和ON COMMIT物化视图的区别,即前者不刷新(手工或自动)就不更新物化视图,而后者不刷新也会更新物化视图,——只要基表发生了COMMIT。

    ON COMMIT物化视图的创建,和上面创建ON DEMAND的物化视图区别不大。因为ON DEMAND是默认的,所以ON COMMIT物化视图,需要再增加个参数即可。   需要注意的是,无法在定义时仅指定ON COMMIT,还得附带个参数才行。

         创建ON COMMIT物化视图:create materialized view mv_name refresh force on commit as select * from table_name    备注:实际创建过程中,基表需要有主键约束,否则会报错(ORA-12014)

      刷新的方法有四种:FAST、COMPLETE、FORCE和NEVER。我们工作中用到的基本上都是FORCE。FAST刷新采用增量刷新,只刷新自上次刷新以后进行的修改。COMPLETE刷新对整个物化视图进行完全的刷新。如果选择FORCE方式,则Oracle在刷新时会去判断是否可以进行快速刷新,如果可以则采用FAST方式,否则采用COMPLETE的方式。NEVER指物化视图不进行任何刷新。

          对于已经创建好的物化视图,可以修改其刷新方式,比如把物化视图mv_name的刷新方式修改为每天晚上10点刷新一次:alter materialized view mv_name refresh force on demand start with sysdate next to_date(concat(to_char(sysdate+1,'dd-mm-yyyy'),' 22:00:00'),'dd-mm-yyyy hh24:mi:ss') 

  • 相关阅读:
    HDOJ 1712 ACboy needs your help(分组背包入门)
    POJ 1742 Coins(多重背包 + 单调队列优化)
    Windows 底层驱动级 AntiRootkit 工具 ScDetective 源代码
    POJ 1252 Euro Efficiency(完全背包变型)
    POJ 2392 Space Elevator(多重背包 + 倍增优化)
    POJ 1384 PiggyBank(完全背包)
    POJ 2063 Investment(完全背包)
    POJ 1014 Dividing(多重背包 + 倍增优化)
    POJ 3260 The Fewest Coins(完全背包 + 多重背包 + 单调队列优化)
    POJ 3264 Balanced Lineup(线段树 单点更新 区间查询)
  • 原文地址:https://www.cnblogs.com/mht91919/p/5795376.html
Copyright © 2011-2022 走看看