公司法
当前位置: 首页 法律大全

数仓项目指的是什么(浅谈数仓建设中的分层)

时间:2023-06-03 作者: 小编 阅读量: 1 栏目名: 法律大全

阿里整体数据分了5层,分别是ODS,DWD,DIM,DWS,ADS,下面我们分别介绍一下。前者是站在与数据源的关系层面来说的,也就是说这一层的数据是跟数据源的数据是一致的,所以称其为贴源数据层。这一层在与原表保持同一粒度的基础上根据业务过程对ODS的数据进行去除脏数据,按照业务过程对表进行归类和关联,经过ETL得到与业务过程相对应的事实表。面向应用层,也就是说是针对单个特定的数据需求清洗而形成的数据。

编辑导语:数仓是我们用来保存大量历史数据的重要工具。那么,数仓为什么要分层?又该怎么进行分层?本文从数仓分层的原因、常见的数仓分层模型、数仓分层的做法三个方面,来详细地介绍数仓分层。快来阅读一下吧。

一、数仓为什么要分层

数仓分层的原因也即是分层的好处体现在下面几个方面:

1. 分层是一种空间换时间的操作

我们知道数仓一般都是用来保存大量的历史数据的,这些数据可能是业务数据也可能是日志数据。

由于数据量级很大,如果直接查询数仓中的原始数据需要访问的表的数量和底层文件的数量都较多,体现在我们日常工作中就是SQL异常复杂,甚至join和union加一起都不够用,造成的直接后果就是SQL运行很慢,甚至跑不出来结果或者报错。

而分层要做的就是对原始数据重新做归纳整理,在不同层级对数据或者指标做不同粒度的抽象。

经过分层后,同一个指标可能在不同层的数据中都有体现,似乎是“重复”了,但这种重复是一种“不完全”的重复,因为每个层级中指标的粒度是不完全一致的。

这种不是完全重复的重复给我们带来的直接好处就是SQL写起来大大简化了,SQL计算耗时大大降低了。

有人可能会质疑这样会造成存储成本的提高,但是相比带来的直接收益,这一点成本是可接受的,毕竟谁也不想被老板一遍又一遍的dis:我要的数怎么还没有跑出来?

2. 分层有利于减少重复开发

分层把大部分常用的、通用的数据模型和指标进行抽象和汇总,经过这样的处理后生成可满足大部分业务场景使用的数据表和指标。

这些表和指标就类似于程序开发中的公共模块和接口,下游的使用方在使用的时候就不需要再从头开发了,直接拿来用即可。

这样不仅减少了重复开发而且做到了数据和指标的统一。

3. 分层可以把复杂的问题简单化

举个例子,大多数分析师刚到一个新公司的时候常常会被迫接手一个甚至是几个长达上千行的祖传SQL代码,里面join、uoion数不过来,一层又一层嵌套的子查询更是剪不断、理还乱。

遇到这样的情况不知道的小白会认为这个前辈很牛逼,能写出这么长的SQL,甚至窃认为自己很幸运学习到了一个这么牛逼的SQL。

但实际情况往往是数仓分层不合理或者刚开始的时候没有数仓,所有的逻辑都要从最底层的表中来计算,这个时候不复杂都难。

而数仓分层要做的一部分工作就是把这个又臭又长的SQL进行拆解和预处理,一方面就是上面提到的把通用的数据和指标进行归类和预计算,另外一方面就是把JOIN和UNION这些复杂的操作拆解放在数仓的ETL中来处理。

这就是所谓的把复杂的问题简单化。

4. 分层带来更高的数据安全

数据经过分层以后,每层的表的宽度和指标的粒度都不同,这样就可以针对不同的使用的对象开放不同层级的数据。

不需要关心明细数据的对方直接开放聚合度高的数据即可,这样就避免了底层明细、敏感数据的泄漏。

另外在分层处理的时候也可以对一些敏感的字段做删除、脱敏加密的处理,避免因安全控制精细化不够带来的数据使用权限大于申请的权限。

分层的其他好处还包括,数据更加规范有条理,数据血缘更加清晰,数据表和指标的统一等等。

二、常用的数仓分层模型

我们以阿里的数仓架构图为例来说明数仓常用的分层模型。

阿里整体数据分了5层,分别是ODS,DWD, DIM,DWS,ADS,下面我们分别介绍一下。

ODS(Operation Data Store)层,中文通常有两种叫法,分别是贴源数据层和操作数据层。

前者是站在与数据源的关系层面来说的,也就是说这一层的数据是跟数据源的数据是一致的,所以称其为贴源数据层。

后者是站在数据产生的层面来说的,也就是说这一层的数据是公司发生的一系列业务动作产生形成的,所以叫操作数据层。

我们可以看到不论是哪一种叫法都体现了与源数据的一致性。

所以这一层的数据一般来说是与业务库中中的数据保持一致的,也即是说这一层的数据来源于业务mysql、oracle等库中或者日志中,在同步的过程中不对数据做任何处理,保证与源数据的一致。

这一层是最基础也是最重要的一层,就像大厦的地基一样,地基不牢,越是高层越是不稳定。

DWD(Data Warehouse Detail),中文称之为明细数据层。

这一层在与原表保持同一粒度的基础上根据业务过程对ODS的数据进行去除脏数据,按照业务过程对表进行归类和关联,经过ETL得到与业务过程相对应的事实表。

通常是实际业务中按照维度建模的方式把一些常用的维度也会冗余的到这一层的表中以降低数据查询的成本。

需要特别提醒的是这一层的数据在粒度上仍然是明细数据,是没有进行聚合的,只是表变得更宽了些。

DIM(Dimension),中文称之为维度数据层。

这一层其实是与DWD平行的一个层级,是对业务中常用维度的建模和抽象,例如常见的地域维度,日期维度,商品品类SKU等维度。所谓的维度也即是我们看数据和分析数据的一种习惯和视角。

这一层通常存储的是完整的维度key和维度的名称,而事实表中通常存储的是维度key的字段。

DWS(Data Warehouse Service),直译为数据服务层,我们通常称其为汇总数据层。

这一层的数据来源基本上都是DWD和DIM,通常是把DWD中的事实表的key和DIM中的维度key关联,然后对事实按照更高的维度进行上卷的聚合操作,得到在某一维度或者多个维度上的汇总数据或指标。

需要提醒的是数据在这一层发生了粒度变化,不再是明细的数据,而是聚合后的数据,这也是这一层别称之为汇总数据层的原因。

ADS(Application Data Service),直译应用数据服务层,也就是我们通常说的应用层或者指标层。

这一层的数据来源可以是DWD层,也可以是DWS层,或者是二者的混合计算。

这一层的数据也是聚合后的数据。

那么它与DWS层的区别是什么呢?

DWS通常是对明细数据按照常用的维度所做的较低维度的聚合汇总,而ADS层通常是面向具体应用(报表、接口等)的较高维度的数据指标的聚合汇总。

举一个不是特别恰当但是很能说明问题的栗子,DWD的10条数据可能在DWS中聚合成了5条,但是在ADS中可能被聚合成了1条,所以二者的聚合度是不一致的。

不过也可能存在二者的聚合度一致,但此时ADS层的表中的字段更多或者更少,这也是体现了其面向具体应用的含义。

以上是阿里数仓的主要分层,抛开具体的层次名称,一般意义上数仓可分为三个大的层次,分别是原始数据层,也就是数仓中数据的来源。

清洗处理层,也就是对原始数据经过各种操作后形成的数据。

面向应用层,也就是说是针对单个特定的数据需求清洗而形成的数据。

明白了这层含义,我也就不用再解释其他一些诸如DWM,FACT,DW,DM等的写法和叫法了,这些都只是表象,核心还是上面说的三层的本质。

三、你的数仓该怎么分层

好多同学可能看了上面的分层介绍后觉得分层不就是那么回事吗?

可是一到实际的场景中就犯了难,ODS中还好说,可是后面要分几层,每一层的原则和依赖怎么定义?

针对一个具体表是放在ADS层合适呢还是放在DWS层合适呢?

下面就来跟大家说说如何对你的数仓分层。

首先我们要记住一个原则:

不要为了分层而去分层,盲目的分层不但会造成数仓中表的混乱而且造成很大的资源浪费更是给后面的数据治理留下的无穷的隐患。

分层的目的是让数据更规范、清晰更易用而不是为了让层次更多。

两点要牢记的是越是往上层数据的粒度就越粗,所表达的内容就越有限,所以不是层级越多越好。

本层的表一般只允许依赖他紧邻的上一层,应严格避免同层依赖,否则极易产生循环依赖。

知道了上面的原则和要点,我的建议是如果业务场景比较简单且数据表也不是很多,三层就足够了。

如果业务场景和过程比较复杂,指标口径需要很多表关联才能计算的话建议四层或者更多的层。

不要为了分层而分层也不要被这个层所层层困住。

一千个读者可能有一千种分层的想法,一千个公司可能也有一千种分层的方法,适合自己的就是最好的。

作者:数据仓库@唐刚,“数据人创作者联盟”成员。

本文由@一个数据人的自留地 原创发布于人人都是产品经理,未经许可,禁止转载。

题图来自 Pexels,基于CC0协议。

,
    推荐阅读
  • 儿童房窗帘颜色禁忌(儿童房窗帘的颜色禁忌说法)

    但过于鲜艳的颜色,对孩子的视力、性格、情绪、神经发育等都可能产生不利的影响。墙面、地板、家具应尽量选择同一色系,并且要遵循“天清地浊”的原则,屋顶尽量用比地板浅的颜色。除非受过专业的训练,否则不建议家长朋友自己尝试混搭色彩。

  • 面食是酸还是碱性(每天都喜欢吃面食的人)

    从国家卫计委等五部门联合发布的《关于调整含铝食品添加剂使用规定的公告》来看,早在2014年7月1日以后,小麦粉及其制品就不能添加含铝泡打粉,除了油炸食品以外。然而,有些不良商贩却为了制作成更美味以及蓬松的包子和馒头,会在面食制作过程中添加含铝泡打粉,它是一种化学复合疏松剂,能让面食迅速泡发,同时变得蓬松,口感好。

  • 2022上半年淮南教师资格证认定指南 2020年淮北教师资格证认定时间

    认定过程中,各级认定机构将对申请人的无犯罪记录情况进行核查,根据查询结果和国家法律法规及有关规定作出认定结论。无传染性疾病,无精神病史,并经教师资格认定机构指定的二级以上医院体检合格。④、驻皖部队现役军人和现役武警应提供由所属部队相关部门出具的申请人隶属该驻皖部队的人事关系证明。

  • 大醋桶怎样清洗干净(怎么大醋桶样清洗干净呢)

    接下来我们就一起去了解一下吧!大醋桶怎样清洗干净白糖:用水浸湿,撒上一勺白糖,用手揉搓,然后用水清洗即可。苏打粉:用水浸湿后,涂上苏打粉,10分钟后用清水洗净即可。新鲜莲藕:用刀把莲藕切开,将莲藕汁涂在醋渣处,10分钟后在水中清洗即可。

  • 满满正能量的句子(满满正能量的好句)

    不怕输,结果未必能赢。但是怕输,结果则一定是输。其他的,交给命运。这世上,时光会改变太多的事情。不要期待,不要假想,不要强求,顺其自然,如果注定,便一定会发生。懂得感恩,是收获幸福的源泉。懂得感恩,你会发现原来自己周围的一切都是那样的美好。就算跑最后一名又怎样,至少我又运动精神。要想改变我们的人生,第一步就是要改变我们的心态。只要心态是正确的,我们的世界就会的光明的。

  • 京东账号怎么注销(如何注销京东账号)

    接下来我们就一起去了解一下吧!京东账号怎么注销页面,点击右上角齿轮图标。在页面,下拉找到并点击。查看是否满足账号注销条件。满足的话,勾选同意须知,点击。注销申请提交成功,等待48小时内审核完毕即可。

  • 地下城与勇士强化和增幅区别(强化增幅小技巧)

    如果你直接去凯丽处从0开始强化,你可能会花费更多的金币而且还伴随着失败的风险,虽然10之前失败不再降低等级,但是能省还是要省一点的。使用垫子某些时候并不是为了提升强化成功的几率,而是将这种连续失败的结果作用于垫子上,从而降低我们继续连败的几率。增幅的垫子成本过大不推荐使用,而在凯丽那里用强化来垫增幅又有些不靠谱,所以增幅还是直接一点比较好。

  • 普信男找女友标准(一口气提七个条件)

    为了早日找到心目中的白马王子,兰兰报名参加了相亲节目。第二天,节目组根据兰兰的择偶标准,为她选择好了相亲对象倪彬。倪彬和兰兰同岁,浙江萧山人,身高1.63米,在广州地区的一个街道办工作,有房有车。男嘉宾表示这个彩礼过高,接受不了,可是兰兰却坚持不让步,主持人只能让男嘉宾先出去,自己来和她交流。最终这场相亲以失败而告终。

  • 怎样调出文字格式选项卡(word文档格式栏不见了怎样找出来)

    怎样调出文字格式选项卡?怎样调出文字格式选项卡打开一个word文档,这个时候你发现格式栏里的字体、字号、对齐等不见了,这个时候你可以重新找回来。点击菜单栏的工具,出现一个下拉菜单,找到自定义按钮,点击。出现了一个自定义的对话框,有工具栏、命令、选项三个标签,点击工具栏标签。这时候你会发现工具栏里面格式前面没有勾选,所以word没有格式栏。勾选格式,然后关闭就可以了。使用起来很方便。

  • 怎样认识科学思维(科学思维指什么)

    接下来我们就一起去研究一下吧!思维科学,研究思维活动规律和形式的科学。思维一直是哲学、心理学、神经生理学及其他一些学科的重要研究内容。辩证唯物主义认为,思维是高度组织起来的物质即人脑的机能,人脑是思维的器官。思维是社会中的人所特有的反映形式,它的产生和发展都同社会实践和语言紧密地联系在一起。