我有一个相当复杂的计算度量,它非常适合多维数据集的每一行数据。但是,我需要逐行计算这些值的总和。但计算度量的行为似乎在 Excel 中的小计和总计行中,它再次执行计算而不是对前面的行求和。有没有办法让计算度量对每一行执行计算,但它们在总计和小计中执行传统的 SUM?
提前致谢。
计算出的措施不汇总;每次都会计算。
有一个解决方案,但这真的很难看:
你必须使用类似的东西
SCOPE([dim1].[hier1].[All]);
[Measures].[MyCalculatedMeasure] = Sum([dim1].[hier1].[bottomlevel].Members, [Measures].[MyCalculatedMeasure]);
END SCOPE;
对于所有维度的所有层次结构,无论是属性还是用户层次结构,根据需要替换
dim1
、hier1
、bottomlevel
。
您需要模仿计算成员的真实测量行为。使用 Null 值制作虚拟真实度量,然后使用范围在粒度级别上定义公式。有关更详细的答案,请参阅此处:http://blog.crossjoin.co.uk/2013/05/29/aggregating-the-result-of-an-mdx-calculation-using-scoped-assignments/
我找到了最简单的方法:
({[Measures].[您在步骤 1 中创建的命名计算]},Leaves())=您的复杂计算;
这在叶级别设置了定义,并且所有聚合都完美运行。