我有一台托管我们的生产和开发数据库的服务器.它使用sql Server Reporting Services运行sql Server 2008(而不是R2).
我将VS 2008 Reporting Services项目部署到服务器以提供报告.所有报告都使用单个共享数据源,当前指向生产数据库.
其他地方的后台服务通过Web服务接口向SSRS创建PDF报告.
我的问题是,在这种环境下,是否可以通过Web服务以编程方式更改要在执行期间使用的数据源,以便报表使用dev或production数据库?
我不想修改共享数据源或报表定义,我只想在执行报表之前设置数据库的名称,我无法看到这是如何实现的.
我能看到的唯一“简单”解决方案是安装另一个报表服务器实例,这对我想要的东西来说似乎有些过分.除非有人给我一个狡猾的答案,否则我即将这样做!
解决方法
是试试这个:
>创建两个报表参数“Server”和“Database”(您应该创建一个默认值,以便默认运行报表)
>将数据源定义为表达式,如下所示:
=“data source =”&参数!Server.Value& “;初始目录=”&参数!Database.Value
现在,您应该能够在运行时动态指定数据库和服务器
请记住,底层数据集定义需要在您执行报告的每个数据库和服务器中有效.
你也可以通过url字符串传递参数,如下所示:
http://server/reportserver?/dir/Report&rs:Command=Render&Server=VALUE1&Database=VALUE2
请记住,这些需要进行URL编码并记住传递Value,而不是Label,如果它们不同的话.