ORACLE中物化视图 prefix = o ns = \"urn:schemas-microsoft-com:office:office\" />
物化视图是包括个查询结果数据库对像它是远程数据本地副本或者用来生成基于数据表求和汇总表物化视图存储基于远程表数据也可以称为快照
物化视图可以查询表视图和其它物化视图
通常情况下物化视图被称为主表(在复制期间)或明细表(在数据仓库中)
对于复制物化视图允许你在本地维护远程数据副本,这些副本是只读如果你想修改本地副本必须用高级复制功能当你想从个表或视图中抽取数据时你可以用从物化视图中抽取
对于数据仓库创建物化视图通常情况下是聚合视图单表聚合视图和连接视图
本篇我们将会看到怎样创建物化视图并且讨论它刷新选项
在复制环境下创建物化视图通常情况下主键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 _disibledevent=> 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 [fast|complete|force]
[on demand | commit]
[start with date] [next date]
[with {primary key|rowid}]]
Refresh选项介绍说明:
a. oracle用刷新思路方法在物化视图中刷新数据.
b. 是基于主键还是基于rowid物化视图
c. 物化视图刷新时间和间隔刷新时间
Refresh思路方法-FAST子句
增量刷新用物化视图日志(参照上面所述)来发送主表已经修改数据行到物化视图中.如果指定REFRESH FAST子句那么应该对主表创建物化视图日志
SQL> CREATE MATERIALIZED VIEW LOG _disibledevent=>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视图,指定了刷新思路方法和自动刷新时间
最新评论