OLTP和OLAP的区别(基础知识)

昨天在牛客网偶然刷到了两个题目,一个是java方法的调用顺序,一个是OLTP和OLAP的区别,今天总结出来给大家看下(来源于百度)

OLTP(ON-LINE TRANSACTION PROCESSING)

  • 概念
    On-Line Transaction Processing联机事务处理过程(OLTP)
    也称为面向交易的处理过程,其基本特征是前台接收的用户数据可以立即传送到计算中心进行处理,并在很短的时间内给出处理结果,是对用户操作快速响应的方式之一。衡量的重要指标是请求+响应时间。

  • 特征
    支持大量并发用户定期添加和修改数据。
    反映随时变化的单位状态,但不保存其历史记录。
    包含大量数据,其中包括用于验证事务的大量数据。
    结构复杂。
    可以进行优化以对事务活动做出响应。
    提供用于支持单位日常运营的技术基础结构。
    个别事务能够很快地完成,并且只需访问相对较少的数据。OLTP 旨在处理同时输入的成百上千的事务。
    实时性要求高
    数据量不是很大。
    交易一般是确定的,所以OLTP是对确定性的数据进行存取。(比如存取款都有一个特定的金额)
    并发性要求高并且严格的要求事务的完整、安全性。

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

OLAP(ON-LINE ANALYTICAL PROCESSING)

  • 概念
    OLAP,也叫联机分析(Online Analytical Processing),有的时候也叫DSS决策支持系统,OLAP是使分析人员、管理人员或执行人员能够从多角度对信息进行快速、一致、交互地存取,从而获得对数据的更深入了解的一类软件技术。OLAP的目标是满足决策支持或者满足在多维环境下特定的查询和报表需求,它的技术核心是"维"这个概念。
  • 分析方法
    维”是人们观察客观世界的角度,是一种高层次的类型划分。“维”一般包含着层次关系,这种层次关系有时会相当复杂。通过把一个实体的多项重要的属性定义为多个维(dimension),使用户能对不同维上的数据进行比较。因此OLAP也可以说是多维数据分析工具的集合。
    OLAP的基本多维分析操作有钻取(roll up和drill down)、切片(slice)和切块(dice)、以及旋转(pivot)、drill across、drill through等。
    钻取是改变维的层次,变换分析的粒度。它包括向上钻取(roll up)和向下钻取(drill down)。roll up是在某一维上将低层次的细节数据概括到高层次的汇总数据,或者减少维数;而drill down则相反,它从汇总数据深入到细节数据进行观察或增加新维。
    切片和切块是在一部分维上选定值后,关心度量数据在剩余维上的分布。如果剩余的维只有两个,则是切片;如果有三个,则是切块。
    旋转是变换维的方向,即在表格中重新安排维的放置(例如行列互换)。
  • 实现方法
    ROLAP表示基于关系数据库的OLAP实现(Relational OLAP)。以关系数据库为核心,以关系型结构进行多维数据的表示和存储。ROLAP将多维数据库的多维结构划分为两类表:一类是事实表,用来存储数据和维关键字;另一类是维表,即对每个维至少使用一个表来存放维的层次、成员类别等维的描述信息。维表和事实表通过主关键字和外关键字联系在一起,形成了"星型模式"。对于层次复杂的维,为避免冗余数据占用过大的存储空间,可以使用多个表来描述,这种星型模式的扩展称为"雪花模式"。
    MOLAP表示基于多维数据组织的OLAP实现(Multidimensional OLAP)。以多维数据组织方式为核心,也就是说,MOLAP使用多维数组存储数据。多维数据在存储中将形成"立方块(Cube)“的结构,在MOLAP中对"立方块"的"旋转”、“切块”、"切片"是产生多维数据报表的主要技术。
    HOLAP表示基于混合数据组织的OLAP实现(Hybrid OLAP)。如低层是关系型的,高层是多维矩阵型的。这种方式具有更好的灵活性。

两者的区别

OLTPOLAP
用户操作人员,底层管理人员决策人员,高级管理人员
功能日常操作处理分析决策
DB 设计面向应用面向主题
数据当前的, 最新的细节的, 二维的分立的历史的, 聚集的, 多维的集成的, 统一的
存取读/写数十条记录读上百万条记录
工作单位简单的事务复杂的查询
用户数上千个上百万个
DB 大小100MB-GB100GB-TB
时间要求具有实时性对时间的要求不严格
主要应用数据库数据仓库

注:以上均来自百度百科

作者:select you from me
链接:https://mp.csdn.net/mdeditor/95049385
来源:CSDN
转载请联系作者获得授权并注明出处。

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
OLTP(Online Transaction Processing)和OLAP(Online Analytical Processing)是两种常见的数据处理方式,它们在数据处理的目的、性质和应用场景上有所区别OLTP主要用于处理实时的交易性数据,即日常的业务操作数据。它支持大量的短期事务,如订单处理、库存管理、银行交易等。OLTP系统通常强调数据的实时性、一致性和高并发处理能力,其目标是快速而准确地处理交易,并保证数据的完整性和可靠性。OLTP系统通常采用关系数据库(如MySQL、Oracle等)作为数据存储和管理的基础。 与之相对,OLAP主要用于分析和决策支持。它处理的数据通常是历史、汇总的和具有分析价值的数据,如销售统计、财务报表、市场趋势等。OLAP系统强调数据的分析、查询和报表功能,其目标是提供灵活、高效的数据分析和决策支持能力。OLAP系统通常采用多维数据模型(如数据立方体)和OLAP数据库(如Microsoft Analysis Services、SAP BusinessObjects等)来组织和管理数据。 因此,OLTPOLAP区别可以总结如下: - 目的:OLTP用于处理实时的交易性数据,OLAP用于分析和决策支持。 - 数据性质:OLTP处理的是实时的、操作性的数据,OLAP处理的是历史的、分析性的数据。 - 应用场景:OLTP适用于日常的业务操作,OLAP适用于数据分析和决策支持。 - 数据模型:OLTP通常采用关系数据模型,OLAP通常采用多维数据模型。 - 数据库类型:OLTP通常使用关系数据库,OLAP通常使用OLAP数据库。 希望这能帮助您理解OLTPOLAP的概念和区别。如果您还有其他问题,可以继续提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值