微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

我有一台托管我们的生产和开发数据库的服务器.它使用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,如果它们不同的话.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐