浅谈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*。FAST刷新采用增量刷新,只刷新自上次刷新以后进行的修改。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,来建立不同等级的聚集物化视图。

    如果对物化视图的基本概念清楚了就比较明白在那里写特定的表空间存储了。
创建物化视图时应先创建存储的日志空间

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;
–基本和对表的操作一致 –物化视图由于是物理真实存在的,故可以创建索引。
创建方式和对普通表创建方式相同,就不在重复写了。

    创建基表更新,物化视图也更新

create materialized view lgc
    build immediate
    refresh on commit
    enable query rewrite
as

    有可能你会碰到当删除基表是物化视图要刷新好长时间可以在基表更新后半分钟刷新视图

ALTER MATERIALIZED VIEW user_order_mavi
  DISABLE QUERY REWRITE
  REFRESH ON DEMAND;

linux

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/1962456.html

(0)
上一篇 2025年2月23日 05:50:25
下一篇 2025年2月23日 05:50:42

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 数据库如何设置主键

    数据库如何设置主键? SQL 设置主键的方法 打开【SQL Server Management Studio】管理工具,连接数据库 【新建表时设置主键】- 打开新建表界面 1)展开要新建表的数据库 2)右键【表】菜单,依次选择【新建】-&g…

    2025年2月23日 数据库
    100
  • 查看表结构的sql语句是什么

    查看表结构的sql语句的方法是: Oracle查看表结构1.命令窗口:desc 表名2.sql窗口:select * from user_tab_columns where table_name=‘大写表名’; MySQL查看表结构 1.查…

    2025年2月23日
    100
  • 数据库基本操作语句有哪些?

    数据库基本操作语句有哪些? 数据库基本操作语句有: 1 关于数据库的基本操作 SHOW DATABASES;  //查询数据库SHOW CREATE DATABASE score; //查询数据库的结构CREATE DATABASE sco…

    2025年2月23日
    100
  • 数据库的常用数据类型有哪些?

    数据库的常用数据类型有哪些? 一、 整数数据类型:整数数据类型是最常用的数据类型之一。   1、INT (INTEGER) INT (或INTEGER)数据类型存储从-2的31次方 (-2 ,147 ,483 ,648) 到2的31次方-1…

    2025年2月23日
    100
  • 数据库update用法详解

    数据库update用法详解 Update是一个数据库SQL语法用语,用途是更新表中原有数据,单独使用时使用where匹配字段。 语法为:UPDATE 表名称 SET 列名dao称 = 新值 WHERE 列名称 = 某值 例如:Update …

    2025年2月23日
    100
  • 要保证数据库的数据独立性需要修改的是什么?

    要保证数据库的数据独立性需要修改的是什么? 要保证数据库的数据独立性需要修改的是模式与内模式的映射。  DBMS提供了两层映像:外模式/模式映像和模式/内模式映像。外模式到模式的映像,保证了数据的逻辑独立性,从模式到内模式的映像,保证了数据…

    2025年2月23日
    100
  • 数据库读写分离是什么意思

    数据库读写分离的意思是为了确保数据库产品的稳定性,很多数据库拥有双机热备功能。也就是,第一台数据库服务器,是对外提供增删改业务的生产服务器;第二台数据库服务器,主要进行读的操作。  读写分离为了确保数据库产品的稳定性,很多数据库拥有双机热备…

    2025年2月23日
    100
  • 数据库的关系运算包括哪些?

    数据库的关系运算包括:1、选择运算,从一个关系R中选择出满足给定条件的所有元组;2、投影运算,从一个关系R所有属性中选择某些指定属性;3、连接运算,是从两个关系的广义笛卡尔积中选取属性间满足一定条件的元组形成一个新关系。 数据库的关系运算包…

    2025年2月23日
    100
  • 数据库索引的作用

    数据库索引的最大作用就是加快查询速度,它能从根本上减少需要扫表的记录行的数量,数据库索引就是数据库的数据结构,进一步说则是该数据结构中存储了一张表中某一列的所有值,也就是说索引是基于数据表中的某一列创建的。     数据库索引是为了增加查询…

    2025年2月23日
    100
  • 数据库的单个数据表中有几个主键?

    数据库的单个数据表中只能有一个主键。数据库主键,指的是一个列或多列的组合,其值能唯一地标识表中的每一行,通过它可强制表的实体完整性;主键主要是用与其他表的外键关联,以及本记录的修改与删除。 数据库的单个数据表中只能有一个主键。 数据库主键,…

    2025年2月23日
    100

发表回复

登录后才能评论