Show data on SSRS report grouped week or month based on parameter
我正在尝试实现在
1 2 3 4 5 | =IIF( Parameters!date_range.value="Weekly", DATEPART("week", FIELDS!DATE.Value), DATEPART("month", FIELDS!DATE.Value) ) |
这会导致以下异常:
The Value expression for the field ‘Date’ contains an error: Argument
'DateValue' cannot be converted to type 'Date'.
(rsRuntimeErrorInExpression). An error has occurred during report
processing. (rsProcessingAborted)
为什么?
实现这一点的最简单方法是首先编写您的查询,该查询会向前拉出这样的结果。
SQL Server 查询
1 2 3 4 5 6 | SELECT DATEPART(MONTH, Date_Column) AS [Monthly] ,DATEPART(WEEK, Date_Column) AS [Weekly] ,SUM(Some_Column) AS Total FROM TABLE_NAME GROUP BY DATEPART(MONTH, Date_Column) ,DATEPART(WEEK, Date_Column) |
SSRS 报告
添加一个矩阵数据区域。将
创建一个
1 2 | 1) Weekly 2) Monthly |
现在在
在
1 | =IIF(Parameters!Groupby.Value ="Monthly", FIELDS!Monthly.Value, FIELDS!Weekly.Value) |
在数据区域
对于列名,您可以使用以下表达式...
1 | =IIF(Parameters!Groupby.Value ="Monthly","Monthly","Weekly") |
你可以走了。
重要提示
SSRS 是一个很酷的数据表示工具,但在数据操作方面并不那么酷,为了获得更好的性能,可以在更接近源(数据库、SQL Server)的地方进行各种数据操作。
所有的演示文稿都应该在 SSRS 上处理。
我建议使用 DATEPART,但我自己发现 SSRS 中的 DATEPART 并不总是像 DATEPART(SSIS 表达式)中描述的那样工作。以下是一些对我有用的具有特定语法的示例:
- =DATEPART("yyyy", Fields!Date.Value) 年份。
- =DATEPART(", Fields!Date.Value) 月份。
- =DATEPART("ww", Fields!Request_Date.Value) 一周。
因此,根据@nshah 的建议将表达式转换为:
1 2 3 4 5 | =IIF( Parameters!date_range.value="Weekly", DATEPART("week", format(FIELDS!DATE.Value,"yyyy-MM-dd")), DATEPART("month", format(FIELDS!DATE.Value,"yyyy-MM-dd")) ) |
尝试类似:
1 | Format(FIELDS!DATE.Value,"yyyy-MM-dd") |
这是 SQL Server 2014 吗?
链接
在 SQL Server 2014 中,DATEPART 将字符串文字隐式转换为 datetime2 类型。这意味着当日期作为字符串传递时,DATEPART 不支持格式 YDM。您必须将字符串显式转换为 datetime 或 smalldatetime 类型才能使用 YDM 格式。