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

前端之家收集整理的这篇文章主要介绍了sql-server – 是否可以在通过Web服务执行SSRS报告期间指定数据源?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一台托管我们的生产和开发数据库的服务器.它使用sql Server Reporting Services运行sql Server 2008(而不是R2).

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

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

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

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

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

解决方法

是试试这个:

>创建两个报表参数“Server”和“@L_301_0@”(您应该创建一个默认值,以便默认运行报表)
>将数据源定义为表达式,如下所示:

=“data source =”&参数!Server.Value& “;初始目录=”&参数!Database.Value

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

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

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

http://server/reportserver?/dir/Report&rs:Command=Render&Server=VALUE1&Database=VALUE2

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

猜你在找的MsSQL相关文章