SSAS中CUBE的多对多关系既可以出现在中间事实表上也可以出现在中间维度表上

开发过SSAS中CUBE的朋友,肯定都知道维度用法中的多对多关系, 这篇文章不想详细阐述多对多关系在CUBE中的结构,详情请在网上寻找CUBE多对多关系的介绍资料。

下面是是一个典型的CUBE中多对多关系的结构图:

可以看到这个多对多关系发生的关键就是中间事实表Fact_PeopleVehicle的DIM_PeopleID字段和DIM_VehcileID字段是多对多的关系,从而使得维度表DIM_Vehcile和事实表Fact_People_Money形成了多对多的关系。然而由于事实表Fact_People_Money和中间事实表Fact_PeopleVehicle都连接到了中间维度表DIM_People的字段ID上,所以在上图的关系中,中间维度表DIM_People本身只是一个1(ID):1(ID)的关系,在整个关系图中只是起到了中间连接的作用。

但是其实中间维度表在CUBE的多对多结构中也是可以产生N:N关系的,我们将上面关系图稍作修改如下:

可以看到现在事实表Fact_People_Money和中间维度表DIM_People的ID字段连接,中间事实表Fact_PeopleVehicle和中间维度表DIM_People的PeopleName字段连接,所以现在事实表Fact_People_Money和中间事实表Fact_PeopleVehicle连接到了中间维度表DIM_People的不同字段上,从而使得中间维度表DIM_People内部产生了1(ID):N(PeopleName)的关系,而不再是1:1的关系,如果ID不是中间维度表DIM_People的主键,甚至可以产生N(ID):N(PeopleName)的关系。所以从上图中我们可以得出结论,在SSAS中CUBE的多对多关系中,多对多不仅可以出现在中间事实表Fact_PeopleVehicle中,还可以出现在中间维度表DIM_People中,也就是说在维度表和事实表之间的任何中间表上都可以产生多对多的关系。

原文地址:https://www.cnblogs.com/OpenCoder/p/6346956.html