首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >无SQL Server2008 R2的数据驱动的SSRS订阅

无SQL Server2008 R2的数据驱动的SSRS订阅
EN

Stack Overflow用户
提问于 2011-11-15 05:02:01
回答 1查看 3.5K关注 0票数 2

我正在尝试模仿数据驱动订阅的功能。我们当前运行的报表服务器版本不允许使用数据驱动下标。目前,这就是我正在使用的

代码语言:javascript
复制
use ReportServer 

declare @datetime varchar(29)
set @datetime = convert(varchar(16),dateadd(MINUTE,2,GETDATE()), 126) +  ':00.000-05:00'


update Subscriptions

set MatchData = '<ScheduleDefinition xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"><StartDateTime xmlns="http://schemas.microsoft.com/sqlserver/2006/03/15/reporting/reportingservices">' + @datetime + '</StartDateTime></ScheduleDefinition>',

modifieddate = convert(varchar(23),GETDATE(), 121)

where SubscriptionID = '48FB6FE9-969B-4E8D-AD37-E80CE20FDDE5'



update Schedule

set StartDate = CONVERT(VARCHAR(16), dateadd(minute, 2, GETDATE()), 121) +   ':00.000',

NextRunTime = null

where Name = '3664a678-af17-4a05-9ff4-5666ea727e91'

它会更新报表服务器,但是当时间到来时,它不会执行。有人知道我怎么才能触发这个吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-11-15 11:23:20

当我留下我的评论时,我的时间很短,但我只是花时间找到了一个好的解释。来自an MSDN blog

创建订阅时,会向RS服务器添加以下内容:

  • 在Subscriptions表中放置一行,用于标识报表的名称、参数设置、数据驱动的查询信息等,以处理订阅
  • 。在计划和ReportSchedule表中放置一行,其中包含subscription
  • 的计时。创建SQL Server代理作业以控制报表的计划执行,该作业存储在MSDB数据库的sysjob和sysjobstep中。代理作业名称是一个代表ScheduleId的GUID值(是的,如果您还没有注意到,这会使您的代理作业列表与一堆guid打乱,从而使您的非订阅作业难以使用:)。

看起来您正在向所需的三个表中的两个创建条目,但您仍然需要创建一个SQL代理作业。

正如作者指出的那样,它们不支持直接操作,所以要进行大量的测试,如果出现问题,不要期望得到太多的支持。

或者,您可以根据SSRS Web服务动态创建这些订阅,比如Subscription and Delivery methods

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8128051

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档