繁体   English   中英

如何将计算列添加到连接到 SSAS 表格模型的数据透视表?

[英]How to add calculated column to a pivot table connected to SSAS tabular model?

或者换句话说,问题是 - 如何根据模型级别中不存在的列在数据透视表中添加一些计算。

我使用AdventureWorksDW2014示例数据库重现了我的问题。

假设我想计算每个组织的FactFinance表中实际和预算方案金额之间的差异,并以数据透视表的形式呈现。

表格模型

为了实现这一点,我创建了一个简单的模型(上面的屏幕)并将SumOfAmount度量添加到FactFinanceSumOfAmount:=SUM([Amount])

接下来,我在 Excel 中打开了我的模型并创建了非常简单的数据透视表(如下所示)

枢轴场主义者 在excel中枢轴

所以,(问题部分)现在我想在我的数据透视表中添加一个额外的列,它应该计算列ActualBudget之间的某些东西(例如差异)。 我希望这个新列成为数据透视表的一部分,这样我就可以过滤它或\\并添加新的分组级别,而无需更改数据透视表“外部”的某些内容。


到目前为止尝试过

我尝试添加计算字段,但似乎我只能使用“真实”列进行计算。 基于来自 COLUMNS 象限的值出现在数据透视表中的列不能用作计算源。

在此处输入图片说明


最终解决方案

我终于把它合并了两个数据透视表:旧的和带有Diff度量的一个,定义为Diff:=[Actual Amount]-[Budget Amount] ,其中

Actual Amount:=Calculate([SumOfAmount];'DimScenario'[ScenarioName] = "Actual")
Budget Amount:=Calculate([SumOfAmount];'DimScenario'[ScenarioName] = "Budget")

正如@WimV 建议的那样在此处输入图片说明

第一个计算的度量是好的:

SumOfAmount:=SUM('FactFinance'[Amount])

添加以下计算度量(如果需要,标记为隐藏):

Budget Amount:=Calculate([SumOfAmount],'DimScenario'[Scenariokey] = "Budget")
Actual Amount:=Calculate([SumOfAmount],'DimScenario'[Scenariokey] = "Actual")

例如,您可以在差异计算中使用新计算

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM