设为首页 收藏本站
查看: 577|回复: 0

[经验分享] Oracle高级应用之物化视图(materialized view)

[复制链接]
YunVN网友  发表于 2016-8-15 07:29:13 |阅读模式
  原文地址:http://hi.baidu.com/gukeming888/blog/item/2682f69481c8237154fb9662.html
  
  物化视图 (Materialized View),在以前的Oracle版本中称为快照(Snapshot)。Oracle的物化视图提供了强大的功能,可以用于预先计算并保存表连接或聚集等 耗时较多的操作的结果,这样在执行查询时,就可以避免进行这些耗时的操作,而从快速地得到结果。
  
  物化视图有很多方面和索引很相似,使用物化视图的目的是为了提高查询性能,物化视图对应用透明,增加和删除物化视图不会影响应用程序中SQL语句的 正确性和有效性,物化视图需要占用存储空间,当基表发生变化时,物化视图也应当刷新。物化视图可以分为以下三种类型:包含聚集的物化视图、只包含连接的物 化视图和嵌套物化视图。
  
  物化视图可以进行分区。而且基于分区的物化视图可以支持分区变化跟踪(PCT)。具有这种特性的物化视图,当基表进行了分区维护操作后,仍然可以进 
行快速刷新操作。对于聚集物化视图,可以在GROUP BY列表中使用CUBE或ROLLUP,来建立不同等级的聚集物化视图。
  
  一、先来看看怎么创建一个物化视图:
  
[sql]  view plaincopy


  • create materialized view vi_emp  
  • refresh force on demand  
  • as  
  • select d.dname,e.ename,e.job,e.hiredate   
  •   from scott.dept d,scott.emp e where d.deptno=e.deptno;  

  
  物化视图的刷新(refresh)的方法有四种:fast、complete、force和never,Oracle默认采用force方式,如上所示。
fast:刷新采用增量刷新,只刷新自上次刷新以后进行的修改。
complete:刷新对整个物化视图进行完全的刷新。
force:刷新时会去判断是否可以进行快速刷新,如果可以则采用fast方式,否则采 用complete的方式。
never:指物化视图不进行任何刷新。
  
  物化视图的类型有两种:on demand和on commit
on demand:顾名思义,仅在该物化视图“需要”被刷新了,才进行刷新(refresh),即更新物化视图,以保证和基表数据的一致性。
on commit:一旦基表有了commit,即事务提交,则立刻刷新,立刻更新物化视图,使得数据和基表一致。
  
  二、创建定时刷新的物化视图(每天晚上10点刷新):
  
[sql]  view plaincopy


  • create materialized view vi_emp  
  • refresh force on demand  
  • start with to_date('03-02-2012 14:50:59', 'dd-mm-yyyy hh24:mi:ss') next to_date(concat(to_char(sysdate + 1, 'yyyy-MM-dd'), ' 22:00:00'), 'yyyy-MM-dd hh24:mi:ss')   
  • as  
  • select d.dname,e.ename,e.job,e.hiredate   
  •   from scott.dept d,scott.emp e where d.deptno=e.deptno;  

  
  三、删除物化视图:
  
[sql]  view plaincopy

  drop materialized view vi_emp; 

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-257965-1-1.html 上篇帖子: C#,Castle,NHibernate,Oracle,最简单的实现 下篇帖子: 调用Oracle EBS SOA服务时常见的几个错误
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表