打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
Oracle中的物化视图
物化视图是包括一个查询结果的数据库对像,它是远程数据的的本地副本,或者用来生成基于数据表求和的汇总表。物化视图存储基于远程表的数据,也可以称为快照。
       物化视图可以查询表,视图和其它的物化视图。
       通常情况下,物化视图被称为主表(在复制期间)或明细表(在数据仓库中)。
       对于复制,物化视图允许你在本地维护远程数据的副本,这些副本是只读的。如果你想修改本地副本,必须用高级复制的功能。当你想从一个表或视图中抽取数据时,你可以用从物化视图中抽取。
       对于数据仓库,创建的物化视图通常情况下是聚合视图,单一表聚合视图和连接视图。
本篇我们将会看到怎样创建物化视图并且讨论它的刷新选项。
       在复制环境下,创建的物化视图通常情况下主键,rowid,和子查询视图。
1.主键物化视图:
              下面的语法在远程数据库表emp上创建主键物化视图
        SQL> CREATE MATERIALIZED VIEW mv_emp_pk
             REFRESH FAST START WITH SYSDATE
            NEXT  SYSDATE + 1/48
            WITH PRIMARY KEY
            AS SELECT * FROM emp@remote_db;
            Materialized view created.
              注意:当用FAST选项创建物化视图,必须创建基于主表的视图日志,如下:
            SQL> CREATE MATERIALIZED VIEW LOG ON emp;
            Materialized view log created.
2.Rowid物化视图
              下面的语法在远程数据库表emp上创建Rowid物化视图
      SQL> CREATE MATERIALIZED VIEW mv_emp_rowid
            REFRESH WITH ROWID
             AS SELECT * FROM emp@remote_db;
            Materialized view log created.
3.子查询物化视图
              下面的语法在远程数据库表emp上创建基于emp和dept表的子查询物化视图
            SQL> CREATE MATERIALIZED VIEW  mv_empdept
            AS SELECT * FROM emp@remote_db e
            WHERE EXISTS
             (SELECT * FROM dept@remote_db d
            WHERE e.dept_no = d.dept_no)
      Materialized view log created.
       REFRESH 子句
                    [refresh [fastcompleteforce]
            [on demand commit]
            [start with date] [next date]
            [with {primary keyrowid}]]
 
       Refresh选项说明:
a.      oracle用刷新方法在物化视图中刷新数据.
b.      是基于主键还是基于rowid的物化视图
c.       物化视图的刷新时间和间隔刷新时间
 
Refresh方法-FAST子句
       增量刷新用物化视图日志(参照上面所述)来发送主表已经修改的数据行到物化视图中.如果指定REFRESH FAST子句,那么应该对主表创建物化视图日志
                    SQL> CREATE MATERIALIZED VIEW LOG ON emp;
Materialized view log created.
       对于增量刷新选项,如果在子查询中存在分析函数,则物化视图不起作用。
Refresh方法- COMPLETE子句
       完全刷新重新生成整个视图,如果请求完全刷新,oracle会完成       完全刷新即使增量刷新可用。
 
Refresh Method – FORCE 子句
       当指定FORCE子句,如果增量刷新可用Oracle将完成增量刷新,否则将完成完全刷新,如果不指定刷新方法(FAST, COMPLETE, or FORCE),Force选项是默认选项
 
主键和ROWD子句
       WITH PRIMARY KEY选项生成主键物化视图,也就是说物化视图是基于主表的主键,而不是ROWID(对应于ROWID子句). PRIMARY KEY是默认选项,为了生成PRIMARY KEY子句,应该在主表上定义主键,否则应该用基于ROWID的物化视图.
       主键物化视图允许识别物化视图主表而不影响物化视图增量刷新的可用性。
       Rowid物化视图只有一个单一的主表,不能包括下面任何一项:
n         Distinct 或者聚合函数.
n         Group by,子查询,连接和SET操作
 
刷新时间      
       START WITH子句通知数据库完成从主表到本地表第一次复制的时间,应该及时估计下一次运行的时间点, NEXT 子句说明了刷新的间隔时间.
            SQL> CREATE MATERIALIZED VIEW mv_emp_pk
                     REFRESH FAST
                  START WITH SYSDATE
                  NEXT  SYSDATE + 2
                  WITH PRIMARY KEY
                  AS SELECT * FROM emp@remote_db;
                  Materialized view created.
在上面的例子中,物化视图数据的第一个副本在创建时生成,以后每两天刷新一次.
 
总结
物化视图提供了可伸缩的基于主键或ROWID的视图,指定了刷新方法和自动刷新的时间。
 
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/uciqxkj/archive/2009/06/01/4227918.aspx
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
CSDN技术中心 ORACLE中的物化视图
oracle物化视图详解
Materialized View
Oracle优化----索引原理篇
物化视图的快速刷新
数据库技术-oracle的优化(同样适用于其他数据库)
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服