是否可以通过Web服务在执行SSRS报告期间指定数据源?

Chr*_*ris 6 sql-server web-services reporting-services ssrs-2008

我有一台托管我们的生产和开发数据库的服务器.它使用SQL Server Reporting Services运行SQL Server 2008(而不是R2).

我将VS 2008 Reporting Services项目部署到服务器以提供报告.所有报告都使用单个共享数据源,当前指向生产数据库.

其他地方的后台服务通过Web服务接口向SSRS创建PDF报告.

我的问题是,在这种环境下,是否可以通过Web服务以编程方式更改要在执行期间使用的数据源,以便报表使用dev或production数据库?

我不想修改共享数据源或报表定义,我只想在执行报表之前设置数据库的名称,我无法看到这是如何实现的.

我能看到的唯一"简单"解决方案是安装另一个报表服务器实例,这对我想要的东西来说似乎有些过分.除非有人给我一个狡猾的答案,否则我即将这样做!

Jas*_*ner 8

是试试这个:

  1. 创建两个报表参数"Server"和"Database"(您应该创建一个默认值,以便默认运行报表)
  2. 将数据源定义为表达式,如下所示:

    ="data source ="&Parameters!Server.Value&"; initial catalog ="&Parameters!Database.Value

现在,您应该能够在运行时动态指定数据库和服务器

请记住,底层数据集定义需要在您执行报告的每个数据库和服务器中有效.

你也可以通过url字符串传递参数,如下所示:

http://server/reportserver?/dir/Report&rs:Command=Render&Server=VALUE1&Database=VALUE2
Run Code Online (Sandbox Code Playgroud)

请记住,这些需要进行URL编码并记住传递Value,而不是Label,如果它们不同的话.