当前位置: 首页 > 图文教程 > 数据库 > Oracle > 对比Caché和Oracle在数据库的应用

Oracle
解决Oracle 9i和Tomcat端口冲突
Oracle JOB的建立,定时执行任务
ORA-01562 和 ORA-01628 问题解决
oracle startup时 ORA-00600错误解决
解决Oracle处理中文乱码的一种方法
用Oracle10g列值掩码技术隐藏敏感数据
如何解决JOB的Interval输入参数过长
理解物化视图刷新过程中出现的约束冲突
Oracle数据库如何查询记录时给记录加锁
两种方法分析每月工作日计算程序
如何避免Oracle数据库密码出现@符号
在Oracle中使用登录触发器初始化用户会话
Oracle数据库中的数据出错的解决办法
Oracle11.2 命令行手工最简创建数据库的过程
Oracle 语句优化分析说明
ORACLE 常用函数总结(80个)
从Oracle 表格行列转置说起
EXECUTE IMMEDIATE用法小结
Oracle 创建用户及数据表的方法
oracle 在一个存储过程中调用另一个返回游标的存储过程

对比Caché和Oracle在数据库的应用


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-30   浏览: 56 ::
收藏到网摘: n/a

  我们做了一个向数据库存放数据以供分析真实应用程序性能的基准测试。为了进行测试,我们对一个基于Oracle的应用程序中的模块用Caché的ObjectScript进行了重写。原模块的功能在Caché上重现只需要40人小时。
  我们记录了基于Caché的单元完成特定任务所需的时间,并和现有的Oracle数据库进行比较,结果是 采用Caché的应用程序快5倍,它仅用280分钟就完成了用Oracle需1441分钟完成的数据加载和过滤任务。

  表格次序模块

  Meralco基于Oracle 8i的表格次序模块用来取得Fields中产生的文本文件,并生成两张表——维表和事实表,他们分别用来分析和报告。为了完成任务,它要执行下列步骤:

  1.表中的多个文本文件(ordenes.txt和gcahorde.txt)要存在两张表ORDENED和GCAHORDE中。在基于Oracle的应用程序中,这通过OracleSQL*Loader来完成。

  2.GCAHORDE表被过滤,生成GCAHORDE-Filtered表。

  3.运用Oracle Package和存储程序,由GCAHORDE-Filtered和ORDENED生成表或维表DD_FIELD_ORDER。

  4.运用Oracle Package和存储程序,由GCAHORDE-Filtered和ORDENED生成D F_FIELD_ORDER

  重写表格次序模块

  Caché允许用ODBC和JDBC存取数据,这样许多传统关系型应用程序只要做少许变动就可以在Caché数据库上运行。象Meralco的表格命令单元这样极度依靠存取程序的应用程序是个例外。把一个传统关系型应用程序转换到Caché,这些存程序需要重新用Caché ObjectScript编写。因此,用Caché ObjectScript重写Field Order模块的功能应该比改写现存的代码要快。

  此方法的另一个好处就是允许基于Caché的单元采用Caché对输入文本文件的预处理功能。因为从原始的gcahorde.txt文件生成的数据进入数据库时就已被过滤了。基于Caché的单元就不需要另外的过滤步骤了。

  在Meralco的指导下,InterSystems开发了基于Caché的Field Order模块,对于熟悉Caché的开发人员只需要40人小时。

  测试结果

  Caché和Oracle 8i的表格命令单元处理相同的文本文件,每种软件完成不同任务的时间都被记录,Caché运行时间比Oracle快4-23倍。结果如下:

  * 共过滤13,396,510 条源记录,加载 90,349 条记录

  结论

  在这个事实的数据仓库应用的性能测试中运行程序中,在执行数据存储和过滤功能时,Caché比Oracle快5倍。把基于Oracle的应用程序重写成基于Caché的应用程序需要40人小时。