1.使用的建模模型
第1部分的总结: 实际企业开发中,一般不会只选择一种,需要根据情况灵活组合,甚至并存(一层维度和多层维度都保存)。整体来看,更倾向于维度更少的星型模型。尤其是大型数据仓库项目,减少表连接的次数,可以显著提升查询效率。星座模型是很多数据仓库的常态,因为很多数据仓库都是多个事实表的。所以星座模型只反映是否有多个事实表,他们之间是否共享一些维度表。
首先数仓建模模型可分为3个: 星型模型 雪花模型 星座模型
(1)星型模型: 一张事实表对应多张维度表, 如下图
(2) 雪花模型: 雪花模型是当有一个或多个维表没有直接连接到事实表上,而是通过其他维表连接到事实表上时,其图解就像多个雪花连接在一起,故称雪花模型。雪花模型是对星型模型的扩展。
如下图
(3)星座模型: 多个事实表共享维度表, 如下图
2.确定表中事实表跟维度表
实际应用中 给到你的源数据, 你针对你负责的主题进行确定你需要的表, 再对你的表进行区分事实表跟维度表。
(1)事实表: 简单来说事实表就是你要关注的内容。(也可以理解成发生的事实)
(2)维度表: 简单来说可以说是看待问题的角度。
比如:某地区商品的销量,是从地区这个角度观察商品销量的。事实表就是销量表,维度表就是地区表。
3.确认会用到哪些表, 然后再数仓中建表
比如我做一个在线销售平台的项目, 负责一个用户主题,用户主题需要到什么表?你要先根据需求文档分析字段, 根据字段再去找表, 这个层度