`
zhuyufufu
  • 浏览: 138794 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

Oracle OLTP OLAP

阅读更多
本文内容转自  Oracle OLAP 与 OLTP 介绍

http://blog.csdn.net/tianlesoftware/article/details/5794844

    数据处理大致可以分成两大类:联机事务处理OLTP(on-line transaction processing)、联机分析处理OLAP(On-Line Analytical Processing)。OLTP是传统的关系型数据库的主要应用,主要是基本的、日常的事务处理,例如银行交易。OLAP是数据仓库系统的主要应用,支持复杂的分析操作,侧重决策支持,并且提供直观易懂的查询结果。

    OLTP 系统强调数据库内存效率,强调内存各种指标的命令率,强调绑定变量,强调并发操作;

    OLAP 系统则强调数据分析,强调SQL执行时长,强调磁盘I/O,强调分区等。

什么是OLTP

    OLTP,也叫联机事务处理(Online Transaction Processing),表示事务性非常高的系统,一般都是高可用的在线系统,以小的事务以及小的查询为主,评估其系统的时候,一般看其每秒执行的Transaction以及Execute SQL的数量。在这样的系统中,单个数据库每秒处理的Transaction往往超过几百个,或者是几千个,Select 语句的执行量每秒几千甚至几万个。典型的OLTP系统有电子商务系统、银行、证券等,如美国eBay的业务数据库,就是很典型的OLTP数据库。

    OLTP系统最容易出现瓶颈的地方就是CPU与磁盘子系统。

       (1)CPU出现瓶颈常表现在逻辑读总量与计算性函数或者是过程上,逻辑读总量等于单个语句的逻辑读乘以执行次数,如果单个语句执行速度虽然很快,但是执行次数非常多,那么,也可能会导致很大的逻辑读总量。设计的方法与优化的方法就是减少单个语句的逻辑读,或者是减少它们的执行次数。另外,一些计算型的函数,如自定义函数、decode等的频繁使用,也会消耗大量的CPU时间,造成系统的负载升高,正确的设计方法或者是优化方法,需要尽量避免计算过程,如保存计算结果到统计表就是一个好的方法。

       (2)磁盘子系统在OLTP环境中,它的承载能力一般取决于它的IOPS处理能力. 因为在OLTP环境中,磁盘物理读一般都是db file sequential read,也就是单块读,但是这个读的次数非常频繁。如果频繁到磁盘子系统都不能承载其IOPS的时候,就会出现大的性能问题。

    OLTP比较常用的设计与优化方式为Cache技术与B-tree索引技术,Cache决定了很多语句不需要从磁盘子系统获得数据,所以,Web cache与Oracle data buffer对OLTP系统是很重要的。另外,在索引使用方面,语句越简单越好,这样执行计划也稳定,而且一定要使用绑定变量,减少语句解析,尽量减少表关联,尽量减少分布式事务,基本不使用分区技术、MV技术、并行技术及位图索引。因为并发量很高,批量更新时要分批快速提交,以避免阻塞的发生。

    OLTP 系统是一个数据块变化非常频繁,SQL 语句提交非常频繁的系统。 对于数据块来说,应尽可能让数据块保存在内存当中,对于SQL来说,尽可能使用变量绑定技术来达到SQL 重用,减少物理I/O 和重复的SQL 解析,从而极大的改善数据库的性能。

    这里影响性能除了绑定变量,还有可能是热快(hot block)。 当一个块被多个用户同时读取时,Oracle 为了维护数据的一致性,需要使用Latch来串行化用户的操作。当一个用户获得了latch后,其他用户就只能等待,获取这个数据块的用户越多,等待就越明显。 这就是热快的问题。 这种热快可能是数据块,也可能是回滚端块。 对于数据块来讲,通常是数据库的数据分布不均匀导致,如果是索引的数据块,可以考虑创建反向所以来达到重新分布数据的目的,对于回滚段数据块,可以适当多增加几个回滚段来避免这种争用。

什么是OLAP

     OLAP,也叫联机分析处理(Online Analytical Processing)系统,有的时候也叫DSS决策支持系统,就是我们说的数据仓库。在这样的系统中,语句的执行量不是考核标准,因为一条语句的执行时间可能会非常长,读取的数据也非常多。所以,在这样的系统中,考核的标准往往是磁盘子系统的吞吐量(带宽),如能达到多少MB/s的流量。

     磁盘子系统的吞吐量则往往取决于磁盘的个数,这个时候,Cache基本是没有效果的,数据库的读写类型基本上是db file scattered read与direct path read/write。应尽量采用个数比较多的磁盘以及比较大的带宽,如4Gb的光纤接口。

     在OLAP系统中,常使用分区技术、并行技术。

     分区技术在OLAP系统中的重要性主要体现在数据库管理上,比如数据库加载,可以通过分区交换的方式实现,备份可以通过备份分区表空间实现,删除数据可以通过分区进行删除,至于分区在性能上的影响,它可以使得一些大表的扫描变得很快(只扫描单个分区)。另外,如果分区结合并行的话,也可以使得整个表的扫描会变得很快。总之,分区主要的功能是管理上的方便性,它并不能绝对保证查询性能的提高,有时候分区会带来性能上的提高,有时候会降低。

     并行技术除了与分区技术结合外,在Oracle 10g中,与RAC结合实现多节点的同时扫描,效果也非常不错,可把一个任务,如select的全表扫描,平均地分派到多个RAC的节点上去。

     在OLAP系统中,不需要使用绑定(BIND)变量,因为整个系统的执行量很小,分析时间对于执行时间来说,可以忽略,而且可避免出现错误的执行计划。但是OLAP中可以大量使用位图索引,物化视图,对于大的事务,尽量寻求速度上的优化,没有必要像OLTP要求快速提交,甚至要刻意减慢执行的速度。

     绑定变量真正的用途是在OLTP系统中,这个系统通常有这样的特点,用户并发数很大,用户的请求十分密集,并且这些请求的SQL 大多数是可以重复使用的。

     对于OLAP系统来说,绝大多数时候数据库上运行着的是报表作业,执行基本上是聚合类的SQL 操作,比如group by,这时候,把优化器模式设置为all_rows是恰当的。 而对于一些分页操作比较多的网站类数据库,设置为first_rows会更好一些。 但有时候对于OLAP 系统,我们又有分页的情况下,我们可以考虑在每条SQL 中用hint。 如:

   Select /*+first_rows(10) */ a.* from table a;

分开设计与优化

    在设计上要特别注意,如在高可用的OLTP环境中,不要盲目地把OLAP的技术拿过来用。

    如分区技术,假设不是大范围地使用分区关键字,而采用其它的字段作为where条件,那么,如果是本地索引,将不得不扫描多个索引,而性能变得更为低下。如果是全局索引,又失去分区的意义。

    并行技术也是如此,一般在完成大型任务时才使用,如在实际生活中,翻译一本书,可以先安排多个人,每个人翻译不同的章节,这样可以提高翻译速度。如果只是翻译一页书,也去分配不同的人翻译不同的行,再组合起来,就没必要了,因为在分配工作的时间里,一个人或许早就翻译完了。

    位图索引也是一样,如果用在OLTP环境中,很容易造成阻塞与死锁。但是,在OLAP环境中,可能会因为其特有的特性,提高OLAP的查询速度。MV也是基本一样,包括触发器等,在DML频繁的OLTP系统上,很容易成为瓶颈,甚至是Library Cache等待,而在OLAP环境上,则可能会因为使用恰当而提高查询速度。

    对于OLAP系统,在内存上可优化的余地很小,增加CPU 处理速度和磁盘I/O 速度是最直接的提高数据库性能的方法,当然这也意味着系统成本的增加。

    比如我们要对几亿条或者几十亿条数据进行聚合处理,这种海量的数据,全部放在内存中操作是很难的,同时也没有必要,因为这些数据快很少重用,缓存起来也没有实际意义,而且还会造成物理I/O相当大。 所以这种系统的瓶颈往往是磁盘I/O上面的。

    对于OLAP系统,SQL 的优化非常重要,因为它的数据量很大,做全表扫描和索引对性能上来说差异是非常大的。

分享到:
评论

相关推荐

    基于Oracle的OLTP与OLAP数据库设计及实现

    文章“基于Oracle的OLTP与OLAP数据库设计及实现”涉及了OLTP与OLAP系统设计的关键技术。首先,文章介绍了OLAP和OLTP的基本概念以及它们的不同应用点。OLTP系统由于需要处理大量的并发用户请求,因此在设计时更侧重于...

    基于Oracle的OLTP与OLAP数据库内存设计和优化.pdf

    基于Oracle的OLTP与OLAP数据库内存设计和优化.pdf

    基于Oracle的OLTP与OLAP数据库设计及实现.pdf

    基于Oracle的OLTP与OLAP数据库设计及实现 基于Oracle的OLTP与OLAP数据库设计及实现是关系型数据库管理系统中的重要组成部分。 在本文中,我们将介绍OLTP和OLAP数据库设计及实现的概念,并讨论基于Oracle的OLTP和...

    Oracle9i OLAP

    ### Oracle9i OLAP知识点详解 #### 一、Oracle9i OLAP简介 **Oracle9i OLAP**是Oracle公司推出的面向联机分析处理(Online Analytical Processing, OLAP)的功能模块之一,专为商业智能(Business Intelligence, ...

    OLTP和OLAP技术融合架构实践.pptx

    【OLTP与OLAP技术融合架构实践】 在线事务处理(OLTP)和在线分析处理(OLAP)是两种不同但互补的数据处理模式。OLTP主要关注于日常事务处理,如银行交易、电子商务订单等,强调高并发、低延迟和数据的一致性。而...

    Oracle OLAP1.pdf

    作为Oracle数据库的一部分,Oracle OLAP与Oracle数据库的集成非常紧密,可以在同一数据库环境中同时管理OLTP和OLAP工作负载,简化了系统的管理和维护。 ### Oracle OLAP的应用场景 Oracle OLAP广泛应用于各种数据...

    ORACLE OLAP

    Oracle OLAP 的出现是为了满足终端用户对数据库查询分析的需求,弥补传统关系数据库(OLTP)在数据分析方面的不足。 OLAP 技术背景 ---------------- 在 1960 年代,关系数据库之父 E.F.Codd 提出了关系模型,...

    数据处理OLTP与OLAP的概念.pdf

    常见的OLTP数据库包括Oracle、MySQL等,它们在处理结构化数据和复杂事务方面表现出色。而非关系型数据库如Redis、MongoDB等则适用于处理非结构化数据,具有较好的横向扩展性。 OLAP则专注于数据分析和决策支持,常...

    OLTP与OLAP业务系统的Oracle优化思路[归类].pdf

    【OLTP与OLAP业务系统的Oracle优化思路】 Oracle数据库在OLTP(联机事务处理)和OLAP(联机分析处理)系统中的优化策略各有侧重,主要体现在对系统特性的理解和针对不同业务需求的调整。 1. **数据库业务类型分类*...

    oracleOLAP.pptx

    Oracle OLAP,全称为Oracle在线分析处理,是Oracle数据库系统中的一个重要组件,专门用于支持复杂的商业智能和数据分析。本讲座将深入探讨Oracle OLAP技术及其在数据仓库和商业智能解决方案中的应用。 首先,OLAP...

    初步了解OLAP

    OLAP 和 OLTP 的区别在于,OLTP 是传统的关系型数据库的主要应用,主要是基本的、日常的事务处理,而 OLAP 是数据仓库系统的主要应用,支持复杂的分析操作,侧重决策支持,并且提供直观易懂的查询结果。 OLAP 的...

    运用Oracle BI Beans开发企业OLAP系统.pdf

    OLAP系统主要用于企业管理和决策支持,它处理的是经过统计和加工后的事务数据,例如销售分析、产品比较等,而不仅仅是传统的事务处理系统(OLTP)中的实时事务记录。 在OLAP系统中,数据通常被组织成多维模型,如...

    一文了解华为Gauss数据库:开发历程、OLTP&OLAP特点、行式&列式存储,及与Oracle和AWS对比…

    GaussDB 200则兼顾在线事务处理和在线分析处理(OLAP),如工商银行就采用了这款产品;而GaussDB 300是一款企业级的分布式HTAP数据库,能够同时处理事务和分析工作负载。 在数据库领域,华为GaussDB与Oracle和AWS的...

    Oracle系统全面学习教程很详细的讲解.docx

    OLAP 与 OLTP 是 Oracle 中两个重要的概念,OLAP 是 On-Line Analytical Processing 的缩写,指的是在线分析处理,而 OLTP 是 On-Line Transactional Processing 的缩写,指的是在线事务处理。两者的区别在于,OLAP ...

    Tianlesoftware Oracle 学习手册(v1.0)高清完整PDF版

    以上是从Tianlesoftware Oracle 学习手册(v1.0)中提取的部分关键知识点,涵盖了OLTP与OLAP的基本概念以及Oracle索引的相关介绍。这些知识点为Oracle初学者提供了一个良好的起点,帮助他们更好地理解和掌握Oracle...

    Dave Oracle 學習手册_v1.2

    #### 1.1 ORACLE OLAP与OLTP介绍 ##### 1.1.1 什么是OLTP(在线事务处理) OLTP是指针对事务处理的场景而设计的数据库应用,主要面向业务操作层的应用程序。其特点是数据量小、并发度高、实时性要求高。例如银行...

    Oracle技术大牛整理文档《Oracle 学习手册》最新版

    首先,手册中提到了Oracle OLTP(在线事务处理)和OLAP(在线分析处理)的介绍。OLTP系统主要面向事务型应用,强调数据库的事务处理能力,如银行交易、预订系统等。而OLAP系统则关注数据仓库和多维数据分析,常用于...

    TiDB&MySql&Oracle介绍及区别

    TiDB 是一款开源的分布式 NewSQL 数据库,设计目标是支持在线事务处理(OLTP)的同时兼顾在线分析处理(OLAP)。它具有高度兼容 MySQL 的特性,可以无缝对接 MySQL 生态系统,让用户在享受分布式数据库的扩展性和高...

Global site tag (gtag.js) - Google Analytics