7

我必须start_date根据报告参数设置我的报告。时间戳在数据库查询中计算。

我的表情是这样的:

=SWITCH (
    Parameters!report_type.Value = 1,First(Fields!daily_start.Value, "Timestamps")
    ,Parameters!report_type.Value = 2,First(Fields!weekly_start.Value, "Timestamps")
    ,Parameters!report_type.Value = 3,First(Fields!monthly_start.Value, "Timestamps")
)

不幸的是,我收到错误消息:

用于报告参数“time_from”的值表达式指的是一个字段。报表参数表达式中不能使用字段

我知道,这是不允许的,因为 SSRS 无法确定调用数据集的顺序。但我认为这并不危险。

所有时间戳都是通过不带参数的查询接收的。该参数report_type由用户在生成报告之前选择。

有人可以给我一个解决方法的提示吗?

4

3 回答 3

3

这是解决方法 - 使用 SQL 获取值。

创建一个名为 StartDates 的新数据集:

SELECT CASE 
    WHEN @report_type = 1 THEN daily_start
    WHEN @report_type = 2 THEN weekly_start 
    WHEN @report_type = 3 THEN monthly_start
END AS StartDate
FROM MyTable

您已经有了@report_type@time_from参数。使用该@time_from参数,将其默认值设置为Get values from a query使用 StartDates 数据集和值字段 StartDate。

现在,您认为这可能足以使其工作 - 您将此查询作为默认值引用,并且当您更改@report_type参数时,其他参数会刷新,但参数中的第一个日期@time_from永远不会改变。这是因为刷新发生在可用值查询上,而不是在默认值查询上。

因此,您还需要将可用值查询连接到 StartDates 查询。现在您的查询将在更改时触发,@report_type默认值将设置为您选择的适当日期。

于 2012-11-27T23:34:02.797 回答
0

我从查询切换到存储过程并收到此错误。我尝试过的事情:

  • 确保我对数据库有足够的权限(您需要 EXEC 权限或 DBO 才能运行 sproc)
  • 删除现有参数(然后使用刷新字段刷新/获取正确命名的参数)
  • 如果您已指定,请删除存储过程周围的方括号
于 2014-07-17T07:02:01.020 回答
0

有时,表达式可能会有点冗长。我创建了一个报告代码函数,然后将其用作参数值。

例如,我创建了一个名为“CalculateDateSet”的代码函数,然后将报表参数设置为此表达式:

"=Code.CalculateDateSet(Parameters!Month.Value, Parameters!Year.Value"

于 2015-09-01T14:19:11.243 回答