文章作者 100test 发表时间 2007:09:06 12:56:20
来源 100Test.Com百考试题网
SQL> 0select * 2 from dba_mview_logs 3 where master = ACCOUNTS . no rows 0selected
0update accounts set last_name = ... where acc_mgr_id = 3.
0select SUBOBJECT_NAME, value from v$segment_statistics where owner = ARUP and OBJECT_NAME = ACCOUNTS and STATISTIC_NAME = logical reads order by SUBOBJECT_NAME / SUBOBJECT_NAME VALUE ------------------------------ ---------- P1 8320 P10 8624 P2 12112 P3 11856 P4 8800 P5 7904 P6 8256 P7 8016 P8 8272 P9 7840 PMAX 256 11 rows 0selected.
execute dbms_mview.refresh( ACC_VIEW , F )
SUBOBJECT_NAME VALUE ------------------------------ ---------- P1 8320 P10 8624 P2 12112 P3 14656 P4 8800 P5 7904 P6 8256 P7 8016 P8 8272 P9 7840 PMAX 256
这些段统计信息显示了在一个逻辑读取过程中选择的段。由于这些统计信息是累积的,因此您必须查看值(而非绝对值)中的更改。如果仔细查看以上值,您便会发现只有分区 P3 的值发生了变化。因此,在刷新过程中只选择了分区 P3 而非整个表,确认 PCT 能否在表即使没有 MV 日志的情况下工作。
即使在基表没有 MV 日志的情况下也可以快速刷新 MV 的能力是一个强大而有用的特性,从而允许您可以在已分区的 MV 中执行快速刷新而不会增加性能开销。我认为,该特性是 Oracle 数据库 10g 第 2 版中最有用的数据仓库增强功能。
相关文章
Oracle数据库中有关CBO优化的三个问题
Oracle10gR2新特性之备份和可用性特性
Oracle10gR2特性之数据仓库和集成特性
Alittletestforindex
澳大利亚华人论坛
考好网
日本华人论坛
华人移民留学论坛
英国华人论坛