我已经构建了一个SSRS报告,该报告应该查看来自具有相似名称的几个表之一的数据 - 即table001,table010,table011等。当我构建报告时,我只包括其中的三个桌子,十几个。一切正常,直到我将所有其余表添加到查询中,使用多个SELECT语句UNIONed;它试图对如此多的数据进行排序,以便花费近半个小时来呈现报告。那不行。
有没有办法将SSRS参数传递给SQL查询,指定要访问的表?
答案 0 :(得分:1)
根据您的评论,您可以执行以下操作
DECLARE @Parameter NVARCHAR(15) = 'Foo'
SELECT CASE
WHEN @Parameter IN ('Foo', 'Bar')
THEN (
SELECT *
FROM table001
)
WHEN @Parameter IN ('Foobar')
THEN (
SELECT *
FROM table002
)
ELSE
(
SELECT *
FROM table003
)
END
的替代地强>
SELECT CASE @Parameter
WHEN 'Foo'
THEN (
SELECT *
FROM table001
)
WHEN 'Bar'
THEN (
SELECT *
FROM table002
)
WHEN 'Foobar'
THEN (
SELECT *
FROM table003
)
ELSE
(
SELECT *
FROM @table004
)
END
答案 1 :(得分:1)
您是否关注过MSDN教程?这也很好:http://sql-bi-dev.blogspot.com/2010/07/report-parameters-in-ssrs-2008.html
请分享您尝试过的内容以及遇到问题的地方。实质上,您在报表中定义参数并将其包含在查询中。 SSRS提供参数值(或通过用户输入接收),然后将最终查询传递给数据库。