【发布时间】:2011-03-17 19:23:01
【问题描述】:
在报告摘要行中计算平均值时出现错误。我的表情是这样的:
=IIF(SUM(Fields!column3.Value) > 0, Format(DateAdd("s", (SUM(Fields!column4.Value) / SUM(Fields!column3.Value)), "00:00:00"), "HH:mm:ss"), "-")
(对不起,超长的线)
当数据看起来像这样时,表达式可以正常工作:
8311 87 0 0
8311 41 0 0
8311 80 0 0
8311 136 1 136
这个想法是,如果第 2 列大于 120,则第 3 列为 1,否则为 0。仅当第 2 列大于 120 时,第 4 列的值才大于 0,在这种情况下,它与列的值相同2. 这样,对于报告服务中该组的汇总行,我能够确定大于 120 的总行数(通过在第 3 列上使用 SUM)。同样,我可以通过对第 4 列求和来确定第 2 列中大于 120 的值的总数。从那里,将第 4 列除以第 3 列来确定第 2 列的平均值应该很简单超过 120 的值。
获得平均值后,我想将其转换为时间字符串(例如,“00:02:16”)。如果没有值(即组中没有超过120的第2列值,我想显示一个“-”。
此逻辑似乎适用于第 2 列的值超过 120 的情况。但是,当第 3 列和第 4 列为 0 时,如下所示:
8310 108 0 0
运行报告时,表达式会给出可怕的#Error 结果。我假设这是除以零的错误,所以我将 IIF 放入表达式中以检查我的平均计算中的分母是否 > 0。
遗憾的是,对于那些在第 3 列和第 4 列中有 0 的组,#Error 仍然存在。我错过了什么?
【问题讨论】:
标签: reporting-services ssrs-2008