1

在数据建模中,一个维度是否可以接受另一个维度的代理键作为属性,还是应该始终是业务键?

我有一个项目维度,它有一个部门编号作为属性。我也有一个部门维度。Item Dimension 是否可以将 SK 保存到 Department Dimension 或仅保留业务 key?

4

1 回答 1

1

通常你会避免在表中同时使用自然键和代理键作为外键,因为这是多余的并且可能导致数据不一致。示例:有人更新自然键并忘记更新代理键。

但是,在您标记请求的数据仓库中,冗余并不是一个问题。通常有一个带有大量插入、更新和删除的事务处理系统,然后是数据仓库。数据仓库从处理系统中获得了所有数据的精美排列,并且没有上面提到的更新。如果数据是冗余的,谁在乎?它简化了数据访问。您甚至可以将员工-部门联接存储为一个表,其中所有部门数据都是冗余的。数据仓库就是要轻松快速地访问数据,从而使报告变得更容易。冗余外键在数据仓库中没有问题。

于 2014-05-30T18:15:34.623 回答