来自 澳门威尼斯人注册网站 2020-01-17 08:37 的文章
当前位置: 澳门威尼斯人平台 > 澳门威尼斯人注册网站 > 正文

Oracle物化视图:创建最简单物化视图

物化视图是一种特殊的物理表,“物化”(Materialized)视图是相对普通视图而言的。普通视图是虚拟表,应用的局限性大,任何对视图的查询,Oracle都实际上转换为视图SQL语句的查询。这样对整体查询性能的提高,并没有实质上的好处。

原文地址:Oracle物化视图创建及管理作者:于士博

一、Oracle物化视图语法

Oracle最早在OLAP系统中引入了物化视图的概念。但后来很多大型OLTP系统中,发现类似统计的查询是无可避免,而这些查询操作如果很频繁,对整体数据库性能是很致命的。于是Oracle开始不断的改进物化视图,使得其也开始合适OLTP系统。从Oracle 8i到现在,功能已经相对比较完备了。

一、前言:

create materialized view [view_name]
refresh [fast|complete|force]
[
on [commit|demand] | start with (start_time) next (next_time)
]
as
{创建物化视图用的查询语句}

本文是Oracle物化视图系列文章的第一篇,有两个主要目的,来体验一下创建ON DEMAND和ON COMMIT物化视图的方法。ON DEMAND和ON COMMIT物化视图的区别在于其刷新方法的不同,ON DEMAND顾名思义,仅在该物化视图“需要”被刷新了,才进行刷新(REFRESH),即更新物化视图,以保证和基表数据的一致性;而ON COMMIT是说,一旦基表有了COMMIT,即事务提交,则立刻刷新,立刻更新物化视图,使得数据和基表一致。

在Oracle文档中,物化视图作为数据仓库的一个技术,但是实际上在OLTP系统中,用来进行数据同步,使用查询重写优化SQL语句都是相当方便的。

         

1、第一个ON DEMAND物化视图

二、物化视图创建

以上是Oracle创建物化视图(Materialized View, 以下简称MV)时常用的语法,各参数的含义如下:

1.1、创建ON DEMAND物化视图

  1、权限

1、refresh [fast|complete|force] 视图刷新的方式:
fast: 增量刷新.假设前一次刷新的时间为t1,那么使用fast模式刷新物化视图时,只向视图中添加t1到当前时间段内主表变化过的数据.为了记录这种变化,建立增量刷新物化视图还需要一个物化视图日志表。create materialized view log on 主表名。
complete: 全部刷新。相当于重新执行一次创建视图的查询语句。
force: 这是默认的数据刷新方式。当可以使用fast模式时,数据刷新将采用fast方式;否则使用complete方式。

下面创建一个最简单的物化视图,这个物化视图的定义很类似于普通视图的创建语句,只是多了一个materialized,但就是这个单词,造成了物化视图和普通视图(虚拟表)的天壤之别,也引申出后面很多的事情,呵呵。

  物化视图中存在三种角色:

2、MV数据刷新的时间:
on demand:在用户需要刷新的时候刷新,这里就要求用户自己动手去刷新数据了(也可以使用job定时刷新)
on commit:当主表中有数据提交的时候,立即刷新MV中的数据;
start ……:从指定的时间开始,每隔一段时间(由next指定)就刷新一次;

本例中需要特别注意的是,Oracle给物化视图的重要定义参数的默认值处理,在下面的例子中会有特别说明。因为物化视图的创建本身是很复杂和需要优化参数设置的,特别是针对大型生产数据库系统而言。但Oracle允许以这种最简单的,类似于普通视图的办法来做,所以不可避免的会涉及到默认值问题。

 分别为:创建者、刷新者、所有者

                 

像我们这样,创建物化视图时未作指定,则Oracle按ON DEMAND模式来创建。

 一般建议这三种角色都为所有者,即你要创建到的schema用户

Oracle的物化视图提供了强大的功能,可以用于预先计算并保存表连接或聚集等耗时较多的操作的结果,这样,在执行查询时,就可以避免进行这些耗时的操作,而从快速的得到结果。物化视图有很多方面和索引很相似:使用物化视图的目的是为了提高查询性能;物化视图对应用透明,增加和删除物化视图不会影响应用程序中SQL语句的正确性和有效性;物化视图需要占用存储空间;当基表发生变化时,物化视图也应当刷新。

从下例中可以看出:

1)创建者需要的权限:

                   

1) 物化视图在某种意义上说就是一个物理表(而且不仅仅是一个物理表),这通过其可以被user_tables查询出来,而得到佐证;

    如果是所有者:CREATE MATERIALIZED VIEW or CREATE ANY MATERIALIZED VIEW

物化视图可以分为以下三种类型:包含聚集的物化视图;只包含连接的物化视图;嵌套物化视图。三种物化视图的快速刷新的限制条件有很大区别,而对于其他方面则区别不大。创建物化视图时可以指定多种选项,下面对几种主要的选择进行简单说明:

2) 物化视图也是一种段(segment),所以其有自己的物理存储属性;

                             CREATE TABLE or CREATE ANY TABLE

1、创建方式(Build Methods):包括BUILD IMMEDIATE(立即)和BUILD DEFERRED(延迟)两种。BUILD IMMEDIATE是在创建物化视图的时候就生成数据,而BUILD DEFERRED则在创建时不生成数据,以后根据需要在生成数据。默认为BUILD IMMEDIATE。 

3) 物化视图会占用数据库磁盘空间,这点从user_segment的查询结果,可以得到佐证。

                             源表和源表的物化视图日志的select权限(如果是远程调用,则赋权限给dblink的user)

2、查询重写(Query Rewrite):包括ENABLE QUERY REWRITE和DISABLE QUERY REWRITE两种。分别指出创建的物化视图是否支持查询重写。查询重写是指当对物化视图的基表进行查询时,Oracle会自动判断能否通过查询物化视图来得到结果,如果可以,则避免了聚集或连接操作,而直接从已经计算好的物化视图中读取数据。默认为DISABLE QUERY REWRITE。

创建物化视图

   如果不是所有者

3、刷新(Refresh):指当基表发生了DML操作后,物化视图何时采用哪种方式和基表进行同步。刷新的模式有两种:ON DEMAND和ON COMMIT。ON DEMAND指物化视图在用户需要的时候进行刷新,可以手工通过DBMS_MVIEW.REFRESH等方法来进行刷新,也可以通过JOB定时进行刷新。ON COMMIT指出物化视图在对基表的DML操作提交的同时进行刷新。刷新的方法有四种:FAST、COMPLETE、FORCE和NEVER。FAST刷新采用增量刷新,只刷新自上次刷新以后进行的修改。COMPLETE刷新对整个物化视图进行完全的刷新。如果选择FORCE方式,则Oracle在刷新时会去判断是否可以进行快速刷新,如果可以则采用FAST方式,否则采用COMPLETE的方式。NEVER指物化视图不进行任何刷新。默认值是FORCE ON DEMAND。

--获取数据库rdbms版本信息

                            创建者:CREATE ANY MATERIALIZED VIEW

           

SQLselect*fromv$version; BANNER

OracleDatabase11gEnterpriseEditionRelease11.1.0.6.0-Production PL/SQLRelease11.1.0.6.0-Production CORE11.1.0.6.0Production TNSfor32-bitWindows:Version11.1.0.6.0-Production NLSRTLVersion11.1.0.6.0Production

--创建物化视图

SQLcreatematerializedviewmv_testcf 2as 3select*fromxiaotg.testcf; Materializedviewcreated

--分析物化视图,以获得统计信息

SQLanalyzetablexiaotg.mv_testcfcomputestatistics; Tableanalyzed

--查看物化视图的行数,发现和master表(TESTCF)一样

SQLselecttl.table_name,tl.num_rowsfromuser_tablestlwheretl.table_namein(TESTCF,MV_TESTCF); TABLE_NAMENUM_ROWS ---------------------------------------- MV_TESTCF80000 TESTCF80000

                            所有者:CREATE TABLE or CREATE ANY TABLE

在建立物化视图的时候可以指定ORDER BY语句,使生成的数据按照一定的顺序进行保存。不过这个语句不会写入物化视图的定义中,而且对以后的刷新也无效。

                                          源表和源表的物化视图日志的select权限(如果是远程调用,则赋权限给dblink的user)

                

2)刷新者是所有者 

4、物化视图日志:如果需要进行快速刷新,则需要建立物化视图日志。物化视图日志根据不同物化视图的快速刷新的需要,可以建立为ROWID或PRIMARY KEY类型的。还可以选择是否包括SEQUENCE、INCLUDING NEW VALUES以及指定列的列表。

                         源表和源表的物化视图日志的select权限(如果是远程调用,则赋权限给dblink的user)

         

     刷新者不是所有者

可以指明ON PREBUILD TABLE语句将物化视图建立在一个已经存在的表上。这种情况下,物化视图和表必须同名。当删除物化视图时,不会删除同名的表。这种物化视图的查询重写要求参数QUERY_REWRITE_INTEGERITY必须设置为trusted或者stale_tolerated。

                         刷新者:alter any materialized view

         

                        所有者: 源表和源表的物化视图日志的select权限(如果是远程调用,则赋权限给dblink的user)

物化视图可以进行分区。而且基于分区的物化视图可以支持分区变化跟踪(PCT)。具有这种特性的物化视图,当基表进行了分区维护操作后,仍然可以进行快速刷新操作。对于聚集物化视图,可以在GROUP BY列表中使用CUBE或ROLLUP,来建立不同等级的聚集物化视图。

三、物化视图创建

            

  物化视图支持的刷新方式:complete、fast、force,分别为全量刷新、增量刷新、默认增量刷新(如果不成功则全量刷新)

-----------------------------------------------------------------------------------  

本文由澳门威尼斯人平台发布于澳门威尼斯人注册网站,转载请注明出处:Oracle物化视图:创建最简单物化视图

关键词: