开发者社区


C++/C | Java | .Net/Windows | Linux/Unix | 开源 | 其他
首页 - 编程
编程
全文搜索:   

用Oracle Materialized views动态创建复杂对象
作者: ZDNET CHINA 特稿
2002-04-04 11:03:03



在数据库结构中,很多动态创建复杂对象的要求常常与响应时间需求相互冲突,对这一棘手问题,Oracle的解决方案就是采用Materialized views,这样,数据库开发人员可以预先加入表格、预先分类、预先归纳复杂的数据仓库信息,因为这些工作要提前完成,因此要给终端用户一定的反应时间,Materialized views对Oracle数据仓库尤为有用,因为此处的交叉表格也会占用很多时间。本文主要探讨了这种方法的内在机理同时也验证一下如何提前做好复杂的统计——让Oracle动态的把SQL重新写入预先设好的统计信息中。

Materialized views 和snapshots

Materialized views是冗余技术的基础,属Oracle snapshots的应急措施。当开发Materialized views的时候,Oracle根本没把它当回儿事儿,Oracle要求定期升级,升级要有一定时间间隔,可能是马上升级也可能每周一次。

人工统计

在Oracle8出现之前,数据库管理员要花很多时间来区分哪些需要创建,以及创建、索引、升级,同时还要告诉用户如何使用,图A列出了整个过程:

图 A

人工创建统计表来提高SQL查询速度

人工创建统计表的问题是你必须要通知端用户访问新列表,Oracle不能自动把SQL写入原有统计表中,现在,Materialized views可以做到这一点。

Materialized views在Oracle系统中应用非常普遍,因为在系统中,性能是关键而且复杂的SQL查询通常要和大型表格打交道。通常我们在两种情况下使用Materialized views:统计和复制。

在统计过程中,Materialized views通过把预先统计好的列表重新写入到原有列表中,从而提高了查询速度,具体做法是:

  • 预先统计——采用总数、平均值、最小值、最大值、count(*)和count(distinct x)
  • 预先加入列表——预先加入列表可以改善系统性能

Materialized views也可以用来复制数据,当然这些数据应该是采用create snapshot存档的,表A中,可以看到Oralce create snapshot语句可以从Oracle声明的“Materialized View Created”中得到回应。

【下一页】
声明:
Builder.com.cn(原ZDNet China应用开发频道)原创文章版权所有,未经许可严禁转载,且不构成投资建议。
近期相关报道:
实用技术文档
J2me XML
C/C++ C#
Java Oracle
Mysql .Net
VB.NET CSS
SQL Server 数据库
SQL UNIX
Linux Jsp
PHP Perl
Javascript IIS
XHTML ColdFusion
ASP/ASP.NET Apache
AJAX
订阅技术邮件
订阅"技术圈"杂志!请在下面选择您感兴趣的专题,填写e-mail地址,然后按订阅按钮:
应用开发管理
VS.NET 周刊
Database 周刊
WEB Service周刊
JAVA 周刊
IT 认证
Windows服务器周刊
互联网开发
当Windows Server 2008专家得5000元现金大奖
CNET NETWORKS 中国: 爱卡汽车网 | CNET科技资讯网 | e询网 | CWEEK | 蜂鸟网 | GameSpot China | 个人电脑 | PChome | SPN | 网友世界 | ZDNet China | 中关村在线
CNET NETWORKS 美国: BNET | CNET.com | CNET Download.com | CNET News.com | CNET Reviews | CNET Shopper.com | GameSpot | MP3.com | mySimon | Release 1.0 | Search.com | TechRepublic | TV.com | Webshots | ZDNet
Copyright (c) 2006 CNET Networks 版权所有。 ZDNet 是CNET Networks公司注册服务商标。
ZDNet 公司标识是 CNET Networks公司注册服务商标。
中华人民共和国电信与信息服务业务经营许可证编号:京ICP证010391号