我正在尝试模仿数据驱动订阅的功能。我们当前运行的报表服务器版本不允许使用数据驱动下标。目前,这就是我正在使用的
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'它会更新报表服务器,但是当时间到来时,它不会执行。有人知道我怎么才能触发这个吗?
发布于 2011-11-15 11:23:20
当我留下我的评论时,我的时间很短,但我只是花时间找到了一个好的解释。来自an MSDN blog
创建订阅时,会向RS服务器添加以下内容:
看起来您正在向所需的三个表中的两个创建条目,但您仍然需要创建一个SQL代理作业。
正如作者指出的那样,它们不支持直接操作,所以要进行大量的测试,如果出现问题,不要期望得到太多的支持。
或者,您可以根据SSRS Web服务动态创建这些订阅,比如Subscription and Delivery methods
https://stackoverflow.com/questions/8128051
复制相似问题