无事实事实和事实表有什么区别?

Has*_*han 3 data-modeling data-warehouse star-schema datamart dimensional-modeling

无事实事实和事实表之间的确切区别是什么?我已经阅读了几篇文章,但它们并不令人信服

jmn*_*mng 7

无事实事实表是没有任何度量的事实表,即任何可以聚合的数字字段。

例如,如果您正在对产品销售建模,您可以拥有一个包含维度键和例如“金额”值/度量的 Sales 事实表,以记录销售金额。这允许您在“金额”字段上运行聚合以回答诸如“平均销售额是多少?”之类的问题。或“最大销售额是多少?”。

但是,如果同一个 Sales 表不包含“amount”字段,则只能使用该表来回答诸如“我们做了多少销售额?”之类的问题。如果该表具有 Product 和 Date 维度的键,您可以回答诸如“我们在日期 Y 中有多少产品 X 的销售量?”之类的问题。

当您只关心记录某个事件发生时,Factless 事实表很有用,例如,当您没有或不需要有关该事件的任何指标/度量时,计算事件的发生次数。

我不是 100% 肯定,但我认为这个概念起源于Kimball 方法论

  • 那是一个绝妙的解释。只有一件事我想知道,在销售事实表中,如果缺少金额字段,但我们仍然可以汇总以了解我们进行了多少销售。那为什么我们说factless 事实表不允许我们运行聚合呢?你能解释一下吗 (2认同)
  • 我明白你的意思;“factless”只是定义为表示对记录很重要但没有其他(相关)定量数据的交易的命名法。在这种情况下,我们只计算表中的行数,而不是在其中一个字段上运行聚合。也许“无度量事实表”会是一个更好的名字:) 我相信这个概念和命名起源于 Kimball 方法:https://www.kimballgroup.com/2011/04/design-tip-133-factless-fact-简化表/. (2认同)