• 离线数仓(7):数仓理论之数据仓库建模


    目录

    0. 相关文章链接

    1. ODS层

    2. DIM层和DWD层

    2.1. 选择业务过程

    2.2. 声明粒度

    2.3. 确定维度

    2.4. 确定事实

    3. DWS层与DWT层

    4. ADS层

    5. 总结


    0. 相关文章链接

     离线数仓文章汇总 

    1. ODS

    在ods层注意如下3点即可:

    • 保持数据原貌不做任何修改,起到备份数据的作用。
    • 数据采用压缩,减少磁盘存储空间(例如:原始数据100G,可以压缩到10G左右;textfile:parquet:orc = 100:30:26,博主这里使用的是parquet和orc格式)
    • 创建分区表,防止后续的全表扫描

    2. DIM层和DWD层

    DIM层DWD层需构建维度模型,一般采用星型模型,呈现的状态一般为星座模型。

    维度建模一般按照以下四个步骤:选择业务过程→声明粒度→确认维度→确认事实

    2.1. 选择业务过程

            在业务系统中,挑选我们感兴趣的业务线,比如下单业务,支付业务,退款业务,物流业务,一条业务线对应一张事实表。

    2.2. 声明粒度

            数据粒度指数据仓库的数据中保存数据的细化程度或综合程度的级别。声明粒度意味着精确定义事实表中的一行数据表示什么,应该尽可能选择最小粒度,以此来应各种各样的需求。

    典型的粒度声明如下:

    • 订单事实表中一行数据表示的是一个订单中的一个商品项。
    • 支付事实表中一行数据表示的是一个支付记录。

    2.3. 确定维度

            维度的主要作用是描述业务是事实,主要表示的是“谁,何处,何时”等信息。确定维度的原则是:后续需求中是否要分析相关维度的指标。例如,需要统计,什么时间下的订单多,哪个地区下的订单多,哪个用户下的订单多。需要确定的维度就包括:时间维度、地区维度、用户维度。

    2.4. 确定事实

            此处的“事实”一词,指的是业务中的度量值(次数、个数、件数、金额,可以进行累加),例如订单金额、下单次数等。在DWD层,以业务过程为建模驱动,基于每个具体业务过程的特点,构建最细粒度的明细层事实表。事实表可做适当的宽表化处理。事实表和维度表的关联比较灵活,但是为了应对更复杂的业务需求,可以将能关联上的表尽量关联上。

    3. DWS层与DWT层

    DWS层和DWT层统称宽表层,这两层的设计思想大致相同,通过以下案例进行阐述:

    • 问题引出:两个需求,统计每个省份订单的个数、统计每个省份订单的总金额
    • 处理办法:都是将省份表和订单表进行join,group by省份,然后计算。同样数据被计算了两次,实际上类似的场景还会更多。

    那怎么设计能避免重复计算呢?

            针对上述场景,可以设计一张地区宽表,其主键为地区ID,字段包含为:下单次数、下单金额、支付次数、支付金额等。上述所有指标都统一进行计算,并将结果保存在该宽表中,这样就能有效避免数据的重复计算。

    总结:

    • 需要建哪些宽表:以维度为基准。
    • 宽表里面的字段:是站在不同维度的角度去看事实表,重点关注事实表聚合后的度量值。
    • DWS和DWT层的区别:DWS层存放的所有主题对象当天的汇总行为,例如每个地区当天的下单次数,下单金额等,DWT层存放的是所有主题对象的累积行为,例如每个地区最近7天(15天、30天、60天)的下单次数、下单金额等。

    4. ADS层

    对各大主题指标分别进行分析

    5. 总结

    • ods层存放最基础的原始数据,不做任何处理,并对数据进行压缩和分区;
    • dwd层对ods层数据进行ETL、炸裂,并以业务过程为驱动,对同一个业务过程数据进行初步聚合;
    • DWS层、DWT层是以需求为驱动,按照主题去创建宽表;主题相当于观察问题的角度。对应着维度表;
    • ADS层同样是以需求为驱动,从DWS和DWT获取数据,并生成需求需要的最终结果数据;

    注:其他 离线数仓 相关文章链接由此进 -> 离线数仓文章汇总


  • 相关阅读:
    关于近期IP-Guard新版本客户端重复发送邮件的问题处理说明
    JAVA练习题38:正则表达式基本练习
    嵌入式分享合集107
    MATLAB配置编译器(包括vs和mingw)
    非连续分配管理方式-基本分页存储管理
    谷粒商城 (二十六) --------- 商品服务 API 新增商品
    使用Apache Kafka 构建实时数据处理应用
    独立咖啡店如何有效经营?看懂十三个生存逻辑就成功了
    Ubuntu搭建AI画图工具stable diffusion-webui
    职业:需求量最大的6个区块链工作
  • 原文地址:https://blog.csdn.net/yang_shibiao/article/details/126672475