【问题标题】:Reporting Services expression gives error in some circumstancesReporting Services 表达式在某些情况下会出错
【发布时间】: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


    【解决方案1】:

    SSRS 中的 iif 与 Visual Basic IIF 相同:它评估所有分支,如果任何部分产生错误,则整个函数都会抛出错误。

    两种常见的解决方法:

    • 在报告中使用嵌入代码,
    • 使用第二个 IIF 可以避免函数被零除。

    第二个选项: 替换:

    =IIF(SUM(Fields!column3.Value) > 0, Format(DateAdd("s", (SUM(Fields!column4.Value) / SUM(Fields!column3.Value)), "00:00:00"), "HH:mm:ss"), "-")
    

    =IIF(SUM(Fields!column3.Value) > 0, Format(DateAdd("s", (SUM(Fields!column4.Value) / IIF(SUM(Fields!column3.Value)>0,SUM(Fields!column3.Value),1)), "00:00:00"), "HH:mm:ss"), "-")
    

    (我认为我得到了正确数量的括号...)

    还有许多处理除以零的嵌入式代码示例,这里有一个。 http://social.msdn.microsoft.com/Forums/is/sqlreportingservices/thread/b8e0730b-da60-49a8-8613-2309ff1a2c90

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2016-01-27
      • 2010-09-06
      • 1970-01-01
      相关资源
      最近更新 更多