将SSRS参数传递给SQL查询

时间:2013-08-01 19:51:07

标签: sql tsql reporting-services bids ssrs-2008-r2

我已经构建了一个SSRS报告,该报告应该查看来自具有相似名称的几个表之一的数据 - 即table001,table010,table011等。当我构建报告时,我只包括其中的三个桌子,十几个。一切正常,直到我将所有其余表添加到查询中,使用多个SELECT语句UNIONed;它试图对如此多的数据进行排序,以便花费近半个小时来呈现报告。那不行。

有没有办法将SSRS参数传递给SQL查询,指定要访问的表?

2 个答案:

答案 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提供参数值(或通过用户输入接收),然后将最终查询传递给数据库。