iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >Oracle物化视图怎么用
  • 185
分享到

Oracle物化视图怎么用

2024-04-02 19:04:59 185人浏览 泡泡鱼
摘要

这篇文章主要介绍了oracle物化视图怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 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物化视图怎么用”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网数据库频道,更多相关知识等着你来学习!

您可能感兴趣的文档:

--结束END--

本文标题: Oracle物化视图怎么用

本文链接: https://www.lsjlt.com/news/65154.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • Oracle物化视图怎么用
    这篇文章主要介绍了Oracle物化视图怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 Oracle物化视图的用法与总结 物...
    99+
    2024-04-02
  • Oracle中怎么创建物化视图
    Oracle中怎么创建物化视图,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 oracle物化视图 一、oracle物化视图基本概念&nb...
    99+
    2024-04-02
  • Oracle物化视图管理及重要视图怎么理解
    这篇文章主要讲解了“Oracle物化视图管理及重要视图怎么理解”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Oracle物化视图管理及重要视图怎么理解”吧!...
    99+
    2024-04-02
  • oracle物化视图快速更新
    建立测试表create table T_table nologging as select * from dba_o...
    99+
    2024-04-02
  • PL/SQL中的视图与物化视图怎么应用
    在PL/SQL中,视图和物化视图是用来简化和优化查询的工具。视图是一个虚拟表,可以像普通表一样被查询,但实际上并不存储任何数据,而是...
    99+
    2024-05-08
    PL/SQL
  • oracle物化视图日志结构是怎样的
    本篇内容介绍了“oracle物化视图日志结构是怎样的”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!orac...
    99+
    2024-04-02
  • Oracle普通视图和物化视图的区别有哪些
    本篇内容主要讲解“Oracle普通视图和物化视图的区别有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Oracle普通视图和物化视图的区别有哪些”吧!物化视...
    99+
    2024-04-02
  • 物化视图详解
    相关内容参考: Oracle 物化视图 说明: https://www.cnblogs.com/xiaohuilong/p/5995596.html   一、物化视图概述 oracl...
    99+
    2024-04-02
  • oracle如何创建、刷新物化视图
    这篇文章将为大家详细讲解有关oracle如何创建、刷新物化视图,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 Create materialized view log ...
    99+
    2024-04-02
  • MongoDB 按需物化视图
    php小编子墨为大家带来了关于MongoDB按需物化视图的介绍。作为一种非关系型数据库,MongoDB提供了物化视图的功能,可以根据实际需求将查询结果以视图的形式存储在数据库中,提高查...
    99+
    2024-02-12
  • oracle中Job怎么定期执行存储刷新物化视图
    本篇内容主要讲解“oracle中Job怎么定期执行存储刷新物化视图”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“oracle中Job怎么定期执行存储刷新物化视图...
    99+
    2024-04-02
  • Oracle如何使用物化视图查询重写query rewrite
    这篇文章主要介绍了Oracle如何使用物化视图查询重写query rewrite,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 ...
    99+
    2024-04-02
  • Postgres怎么使用trigger自动刷新物化视图
    这篇文章主要讲解了“Postgres怎么使用trigger自动刷新物化视图”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Postgres怎么使用trigge...
    99+
    2024-04-02
  • mysql中物化视图的快速刷新测试与物化视图日志分析
    本篇内容介绍了“mysql中物化视图的快速刷新测试与物化视图日志分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学...
    99+
    2024-04-02
  • Oracle中怎么优化复杂视图
    Oracle中怎么优化复杂视图,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。优化方法如果可以将这类视图中常用的谓词条件直接写入视图内,且写成动...
    99+
    2024-04-02
  • PostgreSQL物化视图的示例分析
    这篇文章主要介绍PostgreSQL物化视图的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1、创建视图CREATE MATERIALIZED VIEW&...
    99+
    2024-04-02
  • 12c物化视图中什么是快速刷新
    这篇文章主要介绍了12c物化视图中什么是快速刷新,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。实验之前先明确两个定义:主表:SH.costs...
    99+
    2024-04-02
  • oracle无法实例化视图怎么解决
    如果Oracle无法实例化视图,可能是因为视图的依赖对象不存在或者权限不足。以下是一些解决方法: 确保视图所依赖的表或其他对象存在...
    99+
    2024-03-05
    oracle
  • 12c 物化视图 - 刷新方式的对比
    ...
    99+
    2024-04-02
  • 深入了解MySQLClickHouse中的物化视图功能
    目录数据表与视图ClickHouse的物化视图物化视图的更新使用示例数据表与视图 数据库表是一种关系型数据库中的基本对象,用于存储数据。每个表包含多个列和行,其中每个列代表一种数据类...
    99+
    2023-05-20
    MySQL ClickHouse物化视图 MySQL ClickHouse
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作