4

我一直在研究使用物化视图进行数据聚合和报告的目的,该公司主要以交易为中心(使用 Oracle 数据库)。当前的报告系统依赖于一系列视图,这些视图掩盖了应用程序的许多复杂数据逻辑。这些视图在调用时会给系统带来沉重的负担。

我们有兴趣使用“快速刷新”进行增量更新,以便在用于报告之前执行一些复杂的查询逻辑;但是,组织内部担心物化视图日志(此快速刷新所需的)将对我们当前在数据库中的事务性能产生影响。这种表现对我们的组织非常重要,因此非常害怕任何变化。

这是我们需要实现的物化视图日志类型的示例:

create materialized view log on transaction
  with rowid, sequence(transaction_id,account_id,order_id,currency_id,price,transaction_date,payment_processor_id)
  including new values;

我们不会在更新时使用“on commit”子句,而是在创建视图时使用“on demand”子句,因为我们知道这会对性能产生影响。

实现这种类型的日志记录会影响数据库事务性能吗?我想它一定会稍微影响性能,因为提交中包含了一个额外的写入过程(到日志),但我在 Oracle 文档中找不到对此的任何引用。任何有关此主题的文献或建议将不胜感激。

谢谢你的帮助!

4

1 回答 1

8

是的,会有影响。物化日志需要同步维护,因此事务将需要为基表中修改的每一行将新行插入物化视图日志。影响有多大在很大程度上取决于系统。如果您的系统受 I/O 限制并且您已经对其进行了优化,以便将更改物理写入基表是等待时间的重要部分,那么影响将比您的系统受 CPU 限制并且您的大部分等待时间用于读取数据或执行计算。

如果您真的关心 OLTP 系统的性能,那么将报告分流到不同服务器上的不同数据库是有意义的。您可以使用 Streams(或 GoldenGate,如果您负担得起额外许可)将数据复制到报告服务器,这对源的影响比物化视图要小,因为可以异步读取重做信息(并且可以在报告服务器,而不是将工作负载放在生产服务器上)。然后,您可以在报告服务器上定义物化视图,它们不会对 OLTP 服务器产生任何影响。或者您可以创建一个逻辑备用数据库作为您的报告服务器并在那里创建物化视图。无论哪种方式,

于 2013-07-30T16:09:21.050 回答