博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Oracle高级应用之物化视图(materialized view)
阅读量:6966 次
发布时间:2019-06-27

本文共 1409 字,大约阅读时间需要 4 分钟。

hot3.png

原文地址:

物化视图 (Materialized View),在以前的Oracle版本中称为快照(Snapshot)。Oracle的物化视图提供了强大的功能,可以用于预先计算并保存表连接或聚集等耗时较多的操作的结果,这样在执行查询时,就可以避免进行这些耗时的操作,而从快速地得到结果。

物化视图有很多方面和索引很相似,使用物化视图的目的是为了提高查询性能,物化视图对应用透明,增加和删除物化视图不会影响应用程序中SQL语句的正确性和有效性,物化视图需要占用存储空间,当基表发生变化时,物化视图也应当刷新。物化视图可以分为以下三种类型:包含聚集的物化视图、只包含连接的物化视图和嵌套物化视图。

物化视图可以进行分区。而且基于分区的物化视图可以支持分区变化跟踪(PCT)。具有这种特性的物化视图,当基表进行了分区维护操作后,仍然可以进 

行快速刷新操作。对于聚集物化视图,可以在GROUP BY列表中使用CUBE或ROLLUP,来建立不同等级的聚集物化视图。

一、先来看看怎么创建一个物化视图:

[sql]
  1. create materialized view vi_emp  
  2. refresh force on demand  
  3. as  
  4. select d.dname,e.ename,e.job,e.hiredate   
  5.   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]
  1. create materialized view vi_emp  
  2. refresh force on demand  
  3. 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')   
  4. as  
  5. select d.dname,e.ename,e.job,e.hiredate   
  6.   from scott.dept d,scott.emp e where d.deptno=e.deptno;  

三、删除物化视图:

[sql]
  1. drop materialized view vi_emp; 

转载于:https://my.oschina.net/bluesroot/blog/222463

你可能感兴趣的文章
两个CSS样式生成网站
查看>>
PostgreSQL从继承到分区(三)
查看>>
linux 下清空tomcat catalina.out内容,释放磁盘空间
查看>>
CSS知识点——可替换元素vs不可替换元素
查看>>
记忆碎片 - 2015.09.11
查看>>
关于Windows系统virtualenv环境安装MySQL-Python的解决方案
查看>>
validator的Symbol Coverage没有100%
查看>>
lvs keepalived
查看>>
大规模web服务开发技能
查看>>
Nagios配置之交换机及路由
查看>>
[RabbitMQ]RabbitMQ深入理解(一)进阶/管理/配置
查看>>
跨平台打造移动原生应用的10大武器
查看>>
前段语法处理
查看>>
NAT
查看>>
Linux下SYN***原理与防范措施
查看>>
MySqli 连接失败 MySQL connection not working: 2002 No such file or directory
查看>>
ubuntu12.04升级php5.4至。。5.5
查看>>
Elasticsearch学习总结(02-28 - 03-04)
查看>>
android页面跳转
查看>>
为什么会有jsessionid,这个东东有什么用呢?
查看>>