我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Oracle物化视图怎么用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Oracle物化视图怎么用

这篇文章主要介绍了Oracle物化视图怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

Oracle物化视图的用法与总结

物化视图(material view)是什么?

物化视图是包括一个查询结果的数据库对象,它是远程数据的的本地副本,或者用来生成基于数据表求和的汇总表。

物化视图存储基于远程表的数据,也可以称为快照(类似于MSSQL Server中的snapshot,静态快照)。对于复制,物化视图允许你在本地维护远程数据的副本,这些副本是只读的。

如果你想修改本地副本,必须用高级复制的功能。当你想从一个表或视图中抽取数据时,你可以用从物化视图中抽取。

对于数据仓库,创建的物化视图通常情况下是聚合视图,单一表聚合视图和连接视图。(这个是基于本地的基表或者视图的聚合)。

物化视图,说白了,就是物理表,只不过这张表通过oracle的内部机制可以定期更新,将一些大的耗时的表连接用物化视图实现,会提高查询的效率。当然要打开查询重写选项;

Material View的主要作用

1. 实现两个数据库之间的数据同步,可以存在时间差。

2. 如果是远程链接数据库的场景时,提高查询速度。

(由于查询逻辑复杂,数据量比较大,导致每次查询视图的时候,查询速度慢,效率低下)

物化视图的刷新方式和方法

1. 刷新的方式

Fast

Complete

Fource

2. 刷新的方法

DBMS_REFRESH.Refresh

DBMS_MVIEW.Refresh

EXEC DBMS_MVIEW.refresh('BXJ_OBJECTS_MV_T1','C');
EXEC DBMS_REFRESH.refresh('REP_MVIEWGROUP');  物化视图的刷新方式和方法  (1).在源数据库建立mview log日志文件

        create materialized view log on w_1 ;

----注:(TEST为表名或者视图名,关于视图上建立物化视图,见基于视图的物化视图

----创建物化视图语句:

    (2).在统计数据建立materializad view  语法    

Create materialized view MV_TEST

----MVTEST为物化视图名

Build immediate

----创建时生成数据对应的是build deferred

Refresh fast

----增量刷新

On commit

----在基表有更新时提交,这里该句对视图无效

With rowid

----这里创建基于rowid的物化视图,对应的是 primary key

As

Select * from TEST;

----生成物化视图数据语句

或者

    CREATE MATERIALIZED VIEW MV_TableName
        BUILD IMMEDIATE      --创建时立即刷新
         REFRESH FORCE        --如果可以快速刷新则进行快速刷新,否则完全刷新
         ON DEMAND            --刷新方式
         START WITH SYSDATE   --第一次刷新时间
         NEXT  SYSDATE+1/12   --刷新时间间隔
         AS SELECT 1 id ‘A’ name FROM dual;

    (3).调用时进行刷新

        dbms_refresh.refresh('W_1')

创建物化视图 CREATE MATERIALIZED VIEW bxj_objects_mv_t1 REFRESH FAST AS SELECT * FROM apps.bxj_objects_t1;
CREATE MATERIALIZED VIEW bxj_objects_mv_t2 REFRESH FORCE AS SELECT * FROM bxj_objects_t2;
CREATE MATERIALIZED VIEW bxj_objects_mv_t3 REFRESH COMPLETE AS SELECT * FROM bxj_objects_t3; ON DEMAND和ON COMMIT物化视图的区别 ON DEMAND和ON COMMIT物化视图的区别在于其刷新方法的不同,

ON DEMAND顾名思义,仅在该物化视图“需要”被刷新了,才进行刷新(REFRESH),即更新物化视图,以保证和基表数据的一致性;

而ON COMMIT是说,一旦基表有了COMMIT,即事务提交,则立刻刷新,立刻更新物化视图,使得数据和基表一致。 物化视图是物理表的么? 1) 物化视图在某种意义上说就是一个物理表(但并不仅仅是一个物理表),这通过其可以被user_tables查询出来,而得到佐证;

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

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

查询物化视图上次刷新时间

SELECT last_refresh_date 
     FROM user_mviews 
    WHERE mview_name = 'MV_TABLENAME';

感谢你能够认真阅读完这篇文章,希望小编分享的“Oracle物化视图怎么用”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Oracle物化视图怎么用

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

oracle物化视图怎么设置

物化视图是预先计算的基础表副本,可通过以下步骤设置:创建基础表使用 sql 语句创建物化视图定期刷新物化视图以包含最新数据。Oracle 物化视图设置指南什么是物化视图?物化视图是存储在数据库中对基础表的预计算结果的只读副本。它可以提高
oracle物化视图怎么设置
2024-05-30
2024-04-02

PL/SQL中的视图与物化视图怎么应用

在PL/SQL中,视图和物化视图是用来简化和优化查询的工具。视图是一个虚拟表,可以像普通表一样被查询,但实际上并不存储任何数据,而是通过查询实时生成数据。物化视图则是一个存储在数据库中的表,存储了查询结果,并定期更新以保持数据的最新性。要
PL/SQL中的视图与物化视图怎么应用
2024-05-08

变量在Oracle物化视图中的应用

在Oracle中,物化视图主要用于存储预先计算的结果集,以提高查询性能。它们并不直接支持在物化视图的创建或刷新过程中使用变量。不过,可以通过动态SQL或PL/SQL代码来间接实现变量的使用,从而在一定程度上动态地影响物化视图的查询或刷新行为
变量在Oracle物化视图中的应用
2024-08-27

Index函数与Oracle的物化视图

Index函数和Oracle的物化视图都是用来优化查询性能的工具,但它们的实现方式和作用有所不同。Index函数是数据库中的一种数据结构,用来加快对表中数据的查询速度。当在查询中使用索引时,数据库引擎会直接通过索引定位到数据,而不需要遍历
Index函数与Oracle的物化视图
2024-08-16

MongoDB 按需物化视图

php小编子墨为大家带来了关于MongoDB按需物化视图的介绍。作为一种非关系型数据库,MongoDB提供了物化视图的功能,可以根据实际需求将查询结果以视图的形式存储在数据库中,提高查询性能和灵活性。这种按需物化视图的特性使得开发者可以根据
MongoDB 按需物化视图
2024-02-12

编程热搜

目录