关于 sql:在 SSRS 报告上显示数据,根据参数分组为周或月 | 珊瑚贝

Show data on SSRS report grouped week or month based on parameter


我正在尝试实现在 SSRS 报告中显示的适当分组,该报告由 SSRS 中定义的 \\’weekly\\’ 或 \\’monthly\\’ 参数驱动(不是 sproc 的参数) .为此,我在名为 “Date” 的字段的类别组表达式中使用以下内容(格式为 \\’2014-03-01\\’ 作为示例):

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)

为什么?

  • 你有 dateValue 字段作为日期时间数据类型吗?您可以转换为日期时间类型并重试吗?


实现这一点的最简单方法是首先编写您的查询,该查询会向前拉出这样的结果。

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 报告

添加一个矩阵数据区域。将 Total 列拖放到 DATA.

创建一个Text类型的参数说GROUP ON,并提供值

1
2
1) Weekly
2) Monthly

现在在 ROW GROUPS 窗格中,右键单击唯一可见的行组并转到 GROUP PROPERTIES
在 GROUP ON 部分中放入以下表达式。

1
=IIF(Parameters!Groupby.Value =“Monthly”, FIELDS!Monthly.Value, FIELDS!Weekly.Value)

在数据区域 ROWS 部分使用完全相同的表达式。

对于列名,您可以使用以下表达式…

1
=IIF(Parameters!Groupby.Value =“Monthly”,“Monthly”,“Weekly”)

你可以走了。

重要提示

SSRS 是一个很酷的数据表示工具,但在数据操作方面并不那么酷,为了获得更好的性能,可以在更接近源(数据库、SQL Server)的地方进行各种数据操作。

所有的演示文稿都应该在 SSRS 上处理。

  • 由于我现在使用 SSRS 的经验大约是 2 周,如果我可以将您的建议应用于图表,我不会完全遵循,我的意思是看起来该解决方案实际上可以提供帮助,但我没有将 Matrix 作为表示类型?除非我错过了什么……
  • 你用的是什么图表?
  • 第一个来自 Line 类型


我建议使用 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”))
)
  • 尝试了您的建议并得到与以前相同的错误
  • 难道是因为我有 3 个图表和 3 个 sproc,其中 1 个 SP 不接受 date_range 参数,但返回日期列,我强制 SSRS 按周或月。这就是我对第二张图表的意图,其中第三张图表使用实际接受@date_range 作为参数的SP(默认为在SP 中定义的”每周”)?


尝试类似:

1
Format(FIELDS!DATE.Value,“yyyy-MM-dd”)


这是 SQL Server 2014 吗?

链接
在 SQL Server 2014 中,DATEPART 将字符串文字隐式转换为 datetime2 类型。这意味着当日期作为字符串传递时,DATEPART 不支持格式 YDM。您必须将字符串显式转换为 datetime 或 smalldatetime 类型才能使用 YDM 格式。


来源:https://www.codenong.com/25454025/

微信公众号
手机浏览(小程序)

Warning: get_headers(): SSL operation failed with code 1. OpenSSL Error messages: error:14090086:SSL routines:ssl3_get_server_certificate:certificate verify failed in /mydata/web/wwwshanhubei/web/wp-content/themes/shanhuke/single.php on line 57

Warning: get_headers(): Failed to enable crypto in /mydata/web/wwwshanhubei/web/wp-content/themes/shanhuke/single.php on line 57

Warning: get_headers(https://static.shanhubei.com/qrcode/qrcode_viewid_9541.jpg): failed to open stream: operation failed in /mydata/web/wwwshanhubei/web/wp-content/themes/shanhuke/single.php on line 57
0
分享到:
没有账号? 忘记密码?