`
langzhiwang888
  • 浏览: 182026 次
  • 性别: Icon_minigender_1
  • 来自: 青岛
社区版块
存档分类
最新评论

物化视图语法

 
阅读更多

  create materialized view [view_name]

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

 

 

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

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

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

 

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

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

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

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

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

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

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

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

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

物化视图的基本操作和使用可以查看网址:
http://blog.itpub.net/post/468/13318相关的东东。我主要说明一下使用物化视图的基本东东。如如何建立在特定的表空间上,这些在其他的物化视图上面几乎都没有任何介绍的。主要以我做的一个例子来操作,
如果对物化视图的基本概念清楚了就比较明白在那里写特定的表空间存储了。

创建物化视图时应先创建存储的日志空间

CREATE MATERIALIZED VIEW LOG ON mv_lvy_levytaxbgtdiv
tablespace ZGMV_DATA --日志保存在特定的表空间
WITH ROWID ;
CREATE MATERIALIZED VIEW LOG ON tb_lvy_levydetaildata
tablespace ZGMV_DATA --日志保存在特定的表空间
WITH ROWID,sequence(LEVYDETAILDATAID);
CREATE MATERIALIZED VIEW LOG ON tb_lvy_levydata
tablespace ZGMV_DATA --日志保存在特定的表空间
WITH rowid,sequence(LEVYDATAID);
然后创建物化视图
--创建物化视图
create materialized view MV_LVY_LEVYDETAILDATA
TABLESPACE ZGMV_DATA --保存表空间
BUILD DEFERRED --延迟刷新不立即刷新
refresh force --如果可以快速刷新则进行快速刷新,否则完全刷新
on demand --按照指定方式刷新
start with to_date('24-11-2005 18:00:10', 'dd-mm-yyyy hh24:mi:ss') --第一次刷新时间
next TRUNC(SYSDATE+1)+18/24 --刷新时间间隔
as
SELECT levydetaildataid, detaildatano, taxtermbegin, taxtermend,
......
ROUND(taxdeduct * taxpercent1, 2) - ROUND(taxdeduct * taxpercent2, 2) -
ROUND(taxdeduct * taxpercent3, 2) - ROUND(taxdeduct * taxpercent4, 2) -
ROUND(taxdeduct * taxpercent5, 2) taxdeduct, ROUND(taxfinal * taxpercent1, 2) -
ROUND(taxfinal * taxpercent2, 2) - ROUND(taxfinal * taxpercent3, 2) -
ROUND(taxfinal * taxpercent4, 2) - ROUND(taxfinal * taxpercent5, 2) taxfinal,
a.levydataid, a.budgetitemcode, taxtypecode,
......
FROM tb_lvy_levydetaildata a, tb_lvy_levydata c, MV_LVY_LEVYTAXBGTDIV b
WHERE a.levydataid = c.levydataid
AND a.budgetdistrscalecode = b.budgetdistrscalecode
AND a.budgetitemcode = b.budgetitemcode
AND c.incomeresidecode = b.rcvfisccode
AND C.TAXSTATUSCODE='08'
AND C.NEGATIVEFLAG!='9'
删除物化视图日志
--删除物化视图:
--删除日志: DROP materialized view log on mv_lvy_levytaxbgtdiv;
DROP materialized view log on tb_lvy_levydetaildata;
DROP materialized view log on tb_lvy_levydata;
--删除物化视图 drop materialized view MV_LVY_LEVYDETAILDATA;
--基本和对表的操作一致 --物化视图由于是物理真实存在的,故可以创建索引。

创建方式和对普通表创建方式相同,就不在重复写了。物化视图对于前台数据库使用者来说如同一个实际的表,具有和一般表相同的如select等操作,而其实际上是一个视图,一个由系统实现定期刷新其数据的视图(具体刷新时间在定义物化视图的时候已有定义),使用物化视图更可以实现视图的所有功能,而物化视图却不是在使用时才读取,大大提高了读取速度,特别适用抽取大数据量表某些信息以及数据链连接表使用,但是物化视图占用数据库磁盘空间。具体语法如下:

 

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

 

 具体实例如下:

CREATE MATERIALIZED VIEW an_user_base_file_no_charge
             REFRESH COMPLETE START WITH SYSDATE  
            NEXT  TRUNC(SYSDATE+29)+5.5/24    --红色部分表示从指定的时间开始,每隔一段时间(由next指定)就刷新一次
AS
select distinct user_no
from cw_arrearage t
where (t.mon = dbms_tianjin.getLastMonth or
       t.mon = add_months(dbms_tianjin.getLastMonth, -1))

 

删除物化视图:
drop materialized view an_user_base_file_no_charge;
 

 

 

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

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

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


手动刷新物化视图:

begin
     dbms_mview.refresh(TAB=>'an_user_base_file_no_charge',
                                       METHOD=>'COMPLETE',
                                       PARALLELISM=>8);   --PARALLELISM并行控制参数
end;
/

增量刷新就不需要使用什么并行了,通常情况下,是没有那个必要的。

begin
     dbms_mview.refresh(TAB=>'an_user_base_file_no_charge',
                                       METHOD=>'FAST',
                                       PARALLELISM=>1);
end;
/

分享到:
评论

相关推荐

    Oracle物化视图应用详解

    首先,创建物化视图的基本语法如下: ```sql CREATE MATERIALIZED VIEW schema.name PCTFREE PCTUSED TABLESPACE tablespace_name BUILD IMMEDIATE|DEFERRED ENABLE|DISABLE QUERY REWRITE REFRESH |FAST|...

    1-5+Doris物化视图、索引的典型应用案例.pdf

    创建物化视图的基本语法为: ```sql CREATE MATERIALIZED VIEW [MV name] as [query] [PROPERTIES ("key" = "value")] SELECT select_expr[, select_expr ...] FROM [Base view name] GROUP BY column_name[, column...

    数据库中的物化视图的使用保姆级

    全量物化视图可以对物化视图进行全量更新,语法格式与 CREATE TABLE 语句类似。创建全量物化视图的语法格式为: ``` CREATE MATERIALIZED VIEW [view_name] AS {query_block}; ``` 例如,创建一个全量物化视图,统计...

    Oracle物化视图增量刷新的应用研究.pdf

    "Oracle 物化视图增量刷新的应用研究" Oracle 物化视图是 Oracle 公司提供的一种新技术,可以解决很多普通逻辑视图无法完成的功能。物化视图操作简单,支持增量刷新及全量刷新,可以支持复杂的表连接、聚合函数等...

    oralce创建物化视图

    oralce创建物化视图,基本语法,基本操作

    OCM考试实验笔记之一_物化视图.pdf

    创建物化视图日志的语法类似于: ```sql CREATE MATERIALIZED VIEW LOG ON t1 WITH PRIMARY KEY INCLUDING NEW VALUES; ``` 5. 当物化视图包含最大值(MAX)或最小值(MIN)函数时,无法使用快速刷新。在这种...

    oracle数据快照

    - **创建物化视图日志的基本语法**: ```sql CREATE MATERIALIZED VIEW LOG ON table_name WITH PRIMARY KEY, INCLUDING NEW VALUES; ``` 其中: - `table_name` 是要创建物化视图日志的表名。 - `WITH ...

    oracle view

    Oracle物化视图是数据库管理中的一个重要概念,它是一个包含了查询结果的数据库对象,它可以是远程数据的本地副本,或者用于生成基于数据表的汇总表。物化视图的主要作用在于提供数据的本地缓存,优化查询性能,尤其...

    自己总结的数据库oracle视图用法

    在Oracle中,还可以创建物化视图,这种视图会预先计算并存储结果,适用于需要定期更新且查询频繁的数据。物化视图的刷新可以是手动的,也可以设置为自动定时刷新,以保持数据的实时性。 总的来说,Oracle视图是...

    oracle视图详解

    Oracle 视图详解 Oracle 视图(View)是一种逻辑表,基于一个或多个实际表...在 Oracle 中,还有一种视图:物化视图(MATERIALIZED VIEW),也称实体化视图,快照(8i 以前的说法),它是含有数据的,占用存储空间。

    19.Oracle视图1

    2. **物化视图**:物化视图是存储了查询结果的物理表,常用于数据仓库和OLAP系统中,以提高查询性能,但使用并不广泛。 总之,Oracle视图作为数据访问的窗口,提供了数据安全、简化查询、权限管理和业务逻辑封装等...

    C#演示视图在Select查询语句中的应用

    因此,应合理设计视图,避免在复杂查询中使用视图,或者考虑物化视图(Materialized View)以提升性能。 总结,C#中使用视图配合Select查询语句,可以帮助我们更高效、安全地与数据库进行交互。通过ADO.NET或LINQ,...

    Oracle语法指南.zip

    5. **物化视图**:预先计算并存储视图的结果,提高查询速度。 6. **触发器**:在特定数据库事件发生时自动执行的PL/SQL代码。 7. **数据库链接**:在不同Oracle实例间进行通信和数据共享。 8. **性能优化**:使用...

    oracle10g语法大全

    物化视图是预先计算好的视图,存储实际数据,提供快速查询性能。`CREATE MATERIALIZED VIEW`创建物化视图,可设置刷新策略。 13. **存储过程和函数** 存储过程是预编译的PL/SQL代码块,而函数返回值。它们可以...

    SQL语法范例大全(SQL Server 、Oracle通解)

    7. **物质化查询表**:类似物化视图,但数据不是预先计算的,而是根据需要实时刷新。 8. ** flashback查询**:允许查看数据库的旧状态,恢复误删数据。 9. **数据库链接**:跨数据库查询和操作,连接到其他Oracle...

    oracle_java.rar_oracle

    Oracle数据库还支持一些高级视图功能,如物化视图(Materialized View),这种视图会预先计算并存储查询结果,以提高查询效率。如果王铮的视图是物化视图,他可能使用了以下语句: ```sql CREATE MATERIALIZED VIEW...

    ADBMS4.7-索引视图与分区.pptx

    物化视图则不同,它预先计算并存储了查询结果,提高了数据的访问速度,尤其是在数据查询复杂且重复的情况下。 创建视图的语法通常如下: ```sql CREATE [OR REPLACE] [FORCE|NOFORCE] VIEW view_name [(column_...

    数据库常用SQL语法

    创建物化视图是Oracle数据库的一个强大功能,可以用于加速复杂的查询操作。 #### SQL语句分析: ```sql CREATE MATERIALIZED VIEW td_m_depart_plus BUILD IMMEDIATE REFRESH fast ON DEMAND START WITH sysdate ...

Global site tag (gtag.js) - Google Analytics