0

我有以下表达式应该将月份转换为季度。但是,当我运行报告时,只显示第一季度和第四季度。有人可以看看我的表达,看看它是否正确?我以前从未创建过 SSRS 报告或表达式。

=IIf(Fields!Month.Value/3 <= 1, 1, IIf(Fields!Month.Value/3 > 1 AND Fields!Month.Value <=2, 2, IIf(Fields!Month.Value > 2 and Fields!Month.Value <= 3, 3, 4)))
4

3 回答 3

1

假设Fields!Month.Value是 4。这给出:

=IIf(4/3 <= 1, 1, IIf(4/3 > 1 AND 4 <=2, 2, IIf(4 > 2 and 4 <= 3, 3, 4)))

显然,4/3 <= 1是假的,4/3 > 1 AND 4 <=2是假的,4 > 2 and 4 <= 3是假的,意思是四分之一是4。不正确。

试试这个:

int((Fields!Month.Value - 1) / 3) + 1
于 2012-08-30T15:44:13.040 回答
1

你考虑过使用=DatePart(DateInterval.Quarter, Fields!Month.Value)吗?

于 2012-08-30T18:32:18.240 回答
0

这有效:

=IIF((Fields!Month.Value/3)<=1,1,
  (IIF((Fields!Month.Value/3)<=2,2,
      (IIF((Fields!Month.Value/3)<=3,3,4)))))
于 2012-08-30T15:53:55.203 回答