`
yanMouse
  • 浏览: 39357 次
  • 性别: Icon_minigender_2
  • 来自: 广州
最近访客 更多访客>>
社区版块
存档分类
最新评论

数据仓库建模详解和建模技巧

阅读更多
一、构建企业级数据仓库五步法

  (一)、确定主题

  即确定数据分析或前端展现的主题。例如:我们希望分析某年某月某一地区的啤酒销售情况,这就是一个主题。主题要体现出某一方面的各分析角度(维度)和统计数值型数据(量度)之间的关系,确定主题时要综合考虑。

  我们可以形象的将一个主题想象为一颗星星:统计数值型数据(量度)存在于星星中间的事实表;分析角度(维度)是星星的各个角;我们将通过维度的组合,来考察量度。那么,“某年某月某一地区的啤酒销售情况”这样一个主题,就要求我们通过时间和地区两个维度的组合,来考察销售情况这个量度。从而,不同的主题来源于数据仓库中的不同子集,我们可以称之为数据集市。数据集市体现了数据仓库某一方面的信息,多个数据集市构成了数据仓库。

  (二)、确定量度

  在确定了主题以后,我们将考虑要分析的技术指标,诸如年销售额之类。它们一般为数值型数据。我们或者将该数据汇总,或者将该数据取次数、独立次数或取最大最小值等,这样的数据称为量度。

  量度是要统计的指标,必须事先选择恰当,基于不同的量度可以进行复杂关键性能指标(KPI)等的设计和计算。

  (三)、确定事实数据粒度

  在确定了量度之后,我们要考虑到该量度的汇总情况和不同维度下量度的聚合情况。考虑到量度的聚合程度不同,我们将采用“最小粒度原则”,即将量度的粒度设置到最小。

  例如:假设目前的数据最小记录到秒,即数据库中记录了每一秒的交易额。那么,如果我们可以确认,在将来的分析需求中,时间只需要精确到天就可以的话,我们就可以在ETL处理过程中,按天来汇总数据,此时,数据仓库中量度的粒度就是“天”;反过来,如果我们不能确认将来的分析需求在时间上是否需要精确到秒,那么,我们就需要遵循“最小粒度原则”,在数据仓库的事实表中保留每一秒的数据,以便日后对“秒”进行分析。

  在采用“最小粒度原则”的同时,我们不必担心海量数据所带来的汇总分析效率问题,因为在后续建立多维分析模型(CUBE)的时候,我们会对数据提前进行汇总,从而保障产生分析结果的效率。关于建立多维分析模型(CUBE)的相关问题,我们将在下期栏目中予以阐述。

  (四)、确定维度

  维度是指分析的各个角度。例如我们希望按照时间,或者按照地区,或者按照产品进行分析,那么这里的时间、地区、产品就是相应的维度。基于不同的维度,我们可以看到各量度的汇总情况,也可以基于所有的维度进行交叉分析。

  这里我们首先要确定维度的层次(Hierarchy)和级别(Level)(图四:pic4.bmp)。如图所示,我们在时间维度上,按照“年 -季度-月”形成了一个层次,其中“年”、“季度”、“月”成为了这个层次的3个级别;同理,当我们建立产品维度时,我们可以将“产品大类-产品子类-产品”划为一个层次,其中包含“产品大类”、“产品子类”、“产品”三个级别。

  那么,我们分析中所用到的这些维度,在数据仓库中的存在形式是怎样的呢?
我们可以将3个级别设置成一张数据表中的3个字段,比如时间维度;我们也可以使用三张表,分别保存产品大类、产品子类、产品三部分数据,比如产品维度.

  另外,值得一提的是,我们在建立维度表时要充分使用代理键。代理键是数值型的ID号码(例如图六中每张表的第一个字段),它唯一标识了每一维度成员。更重要的是,在聚合时,数值型字段的匹配和比较,JOIN效率高,便于聚合。同时,代理键对缓慢变化维度有着重要的意义,在原数据主键相同的情况下,它起到了对新数据与历史数据的标识作用。

  在此,我们不妨谈一谈维度表随时间变化的问题,这是我们经常会遇到的情况,我们称其为缓慢变化维度。

  比如我们增加了新的产品,或者产品的ID号码修改了,或者产品增加了一个新的属性,此时,维度表就会被修改或者增加新的记录行。这样,我们在ETL的过程中,就要考虑到缓慢变化维度的处理。对于缓慢变化维度,有三种情况:

  1、缓慢变化维度第一种类型:

  历史数据需要修改。这种情况下,我们使用UPDATE方法来修改维度表中的数据。例如:产品的ID号码为123,后来发现ID号码错了,需要改写成456,那么,我们就在ETL处理时,直接修改维度表中原来的ID号码为456。

  2、缓慢变化维度第二种类型:

  历史数据保留,新增数据也要保留。这时,要将原数据更新,将新数据插入,我们使用UPDATE / INSERT。比如:某一员工2005年在A部门,2006年时他调到了B部门。那么在统计2005年的数据时就应该将该员工定位到A部门;而在统计 2006年数据时就应该定位到B部门,然后再有新的数据插入时,将按照新部门(B部门)进行处理,这样我们的做法是将该维度成员列表加入标识列,将历史的数据标识为“过期”,将目前的数据标识为“当前的”。另一种方法是将该维度打上时间戳,即将历史数据生效的时间段作为它的一个属性,在与原始表匹配生成事实表时将按照时间段进行关联,这种方法的好处是该维度成员生效时间明确。

  3、缓慢变化维度第三种类型:

  新增数据维度成员改变了属性。例如:某一维度成员新加入了一列,该列在历史数据中不能基于它浏览,而在目前数据和将来数据中可以按照它浏览,那么此时我们需要改变维度表属性,即加入新的字段列。那么,我们将使用存储过程或程序生成新的维度属性,在后续的数据中将基于新的属性进行查看。

  (五)、创建事实表

  在确定好事实数据和维度后,我们将考虑加载事实表。

  在公司的大量数据堆积如山时,我们想看看里面究竟是什么,结果发现里面是一笔笔生产记录,一笔笔交易记录… 那么这些记录是我们将要建立的事实表的原始数据,即关于某一主题的事实记录表。

  我们的做法是将原始表与维度表进行关联,生成事实表(图六:pic6.bmp)。注意在关联时有为空的数据时(数据源脏),需要使用外连接,连接后我们将各维度的代理键取出放于事实表中,事实表除了各维度代理键外,还有各量度数据,这将来自原始表,事实表中将存在维度代理键和各量度,而不应该存在描述性信息,即符合“瘦高原则”,即要求事实表数据条数尽量多(粒度最小),而描述性信息尽量少。

  如果考虑到扩展,可以将事实表加一唯一标识列,以为了以后扩展将该事实作为雪花型维度,不过不需要时一般建议不用这样做。

  事实数据表是数据仓库的核心,需要精心维护,在JOIN后将得到事实数据表,一般记录条数都比较大,我们需要为其设置复合主键和索引,以实现数据的完整性和基于数据仓库的查询性能优化。事实数据表与维度表一起放于数据仓库中,如果前端需要连接数据仓库进行查询,我们还需要建立一些相关的中间汇总表或物化视图,以方便查询。

  二、项目模型实践技巧

  (一)、准备区的运用

  在构建数据仓库时,如果数据源位于一台服务器上,数据仓库在另一台服务器端,考虑到数据源Server端访问频繁,并且数据量大,需要不断更新,所以可以建立准备区数据库(图八:pic8.bmp)。先将数据抽取到准备区中,然后基于准备区中的数据进行处理,这样处理的好处是防止了在原 OLTP系统中频繁访问,进行数据运算或排序等操作。

  例如我们可以按照天将数据抽取到准备区中,基于数据准备区,我们将进行数据的转换、整合、将不同数据源的数据进行一致性处理。数据准备区中将存在原始抽取表、转换中间表和临时表以及ETL日志表等。

  (二)、时间戳的运用

  时间维度对于某一事实主题来说十分重要,因为不同的时间有不同的统计数据信息,那么按照时间记录的信息将发挥很重要的作用。在ETL中,时间戳有其特殊的作用,在上面提到的缓慢变化维度中,我们可以使用时间戳标识维度成员;在记录数据库和数据仓库的操作时,我们也将使用时间戳标识信息。例如:在进行数据抽取时,我们将按照时间戳对OLTP系统中的数据进行抽取,比如在午夜0:00取前一天的数据,我们将按照OLTP系统中的时间戳取 GETDATE到GETDATE减一天,这样得到前一天数据。

  (三)、日志表的运用

  在对数据进行处理时,难免会发生数据处理错误,产生出错信息,那么我们如何获得出错信息并及时修正呢? 方法是我们使用一张或多张Log日志表,将出错信息记录下来,在日志表中我们将记录每次抽取的条数、处理成功的条数、处理失败的条数、处理失败的数据、处理时间等等。这样,当数据发生错误时,我们很容易发现问题所在,然后对出错的数据进行修正或重新处理。

  (四)、使用调度

  在对数据仓库进行增量更新时必须使用调度(图九:pic9.bmp),即对事实数据表进行增量更新处理。在使用调度前要考虑到事实数据量,确定需要多长时间更新一次。比如希望按天进行查看,那么我们最好按天进行抽取,如果数据量不大,可以按照月或半年对数据进行更新。如果有缓慢变化维度情况,调度时需要考虑到维度表更新情况,在更新事实数据表之前要先更新维度表。

  调度是数据仓库的关键环节,要考虑缜密。在ETL的流程搭建好后,要定期对其运行,所以调度是执行ETL流程的关键步骤。每一次调度除了写入 Log日志表的数据处理信息外,还要使用发送Email或报警服务等,这样也方便的技术人员对ETL流程的把握,增强了安全性和数据处理的准确性。

分享到:
评论

相关推荐

    数据仓库维度建模详解!

    数据仓库维度建模详解!

    数据仓库详解(秘史)

    4. 自动化和智能化:AI和机器学习在数据仓库中的应用,提升数据建模和优化的自动化程度。 总结,数据仓库作为企业的重要基础设施,其设计、构建和使用对于企业的数据驱动决策至关重要。不断演进的技术和应用场景...

    独一无二的数据仓库建模指南系列教程升级版.txt

    ### 数据仓库建模指南知识点详解 #### 一、引言 在当今大数据时代,数据仓库作为企业级数据处理的核心组成部分,对于企业的决策支持系统(DSS)至关重要。一个设计合理、构建良好的数据仓库能够帮助企业更好地收集...

    数据仓库建模 Powerdesigner 维度建模 软件分析 建模 视频教程

    ### 数据仓库建模与PowerDesigner维度建模详解 #### 一、数据仓库的概念与作用 数据仓库(Data Warehouse)是一种用于存储和管理企业历史数据的系统,它将来自不同源系统的数据集成到一起,以便进行深入的数据分析...

    oracle数据仓库建模

    Oracle 数据仓库建模通常遵循两种主流的方法论:规范化的第三范式(3NF)建模和星型模式建模。 - **第三范式(3NF)建模**:这是一种传统的数据库设计方法,强调数据的规范化以减少数据冗余并提高数据一致性。在3NF...

    数据仓库建模技术介绍

    ### 数据仓库建模技术知识点详解 #### 一、引言 数据仓库的构建是一个复杂的过程,其中的关键步骤之一就是数据仓库的建模。良好的数据仓库建模不仅能够准确地反映业务部门的需求,还能够为后续的数据仓库物理实现...

    数据仓库建模方法论2018-3-29.pdf

    总结来说,数据仓库建模是一个复杂而关键的过程,它涉及到对业务的深入理解,模型的精心设计,以及对物理实现的考虑。维度建模作为一种实用方法,通过简化业务过程,强化业务视角,为数据分析提供了高效的支持。

    浅谈数据仓库建设中的数据建模方法

    #### 三、数据仓库建模方法详解 1. **概念模型**:例如TERADATA的FS-LDM(Financial Services Logical Data Model)。FS-LDM是一个高度抽象的模型,它描述了金融服务业内的数据概念和关系。FS-LDM不仅涵盖了银行...

    数据仓库与数据挖掘整套详解教程

    数据仓库与数据挖掘是...总之,"数据仓库与数据挖掘整套详解教程"将为你提供一套全面的知识体系,无论你是数据分析师、业务顾问还是对数据科学感兴趣的初学者,都能从中受益匪浅,提升你的数据分析能力和商业洞察力。

    DM数据仓库建模

    ### 数据仓库建模的核心知识点 #### 一、为何需要数据仓库模型? 数据仓库建模是构建数据仓库过程中不可或缺的一部分,其重要性在于为数据仓库提供一个清晰、有序且高效的结构框架。模型的设计能够确保数据的一致...

    数仓建模-数据仓库(Data Warehouse)中对数据进行组织、设计和建模

    数据仓库建模是根据业务需求和数据特性设计数据模型的过程。主要的建模方法有两种:维度建模和规范化建模。 - **维度建模**:这是一种面向业务用户的设计方法,通过建立事实表和维度表来组织数据。事实表通常包含...

    数据仓库工具箱 第三版

    《数据仓库工具箱:第三版》由Ralph Kimball和Margy Ross编写,是关于维度建模和数据仓库设计的经典之作。本书不仅深入探讨了上述知识点,还提供了大量实用案例和最佳实践指南,对于希望深入了解这一领域的专业人士...

    数据仓库维度建模技术在电信行业的应用.doc

    数据仓库的建模过程包括物理建模和逻辑建模两大部分。物理建模主要关注数据的存储和访问效率,而逻辑建模则更侧重于满足具体应用需求,直接反映业务部门的分析需求,对后续的物理实现有重要指导意义。 ##### 1.1 ...

    数据规范建模详解.pdf

    数据规范建模详解 数据规范建模是大数据和数据中台的重要组成部分,对数据进行分层和规范设计,能够提高数据的可维护性、可扩展性和可重用性。本文将详细介绍数据规范建模的流程和方法。 数据规范建模流程: 1. ...

    数据仓库维度建模笔记

    ### 数据仓库维度建模知识点详解 #### 一、数据仓库体系结构和建模过程、技巧 **1.... 数据仓库建设的核心驱动力是业务需求。...通过遵循上述指导原则和技巧,可以构建出既符合业务需求又能支持高效查询的数据仓库模型。

    数仓建模方法和数仓分层架构详解.pdf

    在业务系统和数据仓库建模中,也存在着一些区别。在业务系统中,通常面对业务库的随机读写,主要采用三范式(3NF)模型存储数据。而在数据仓库的建模过程中,由于主要是数据的批量读取操作,并且事务不是我们所关心...

    数据仓库维度建模设计原则及应用

    在设计维度模型时,遵循一定的设计原则是非常重要的,这有助于提高数据仓库的整体性能和可用性。 ##### 2.1 事实表的设计原则 - **更少的列和更多的行**:事实表应该包含较少的列,但更多的行。这意味着去除与决策...

Global site tag (gtag.js) - Google Analytics