SQL Server维护计划历史记录检查状态

SQL Server维护计划历史记录检查状态,sql,sql-server,prtg,Sql,Sql Server,Prtg,如果仍在运行,我需要监控维护计划,我找到了一个旧帖子(感谢Don)来查询日志并获取作业结果,但这只会在完成后给出结果: SELECT mp.name AS [MTX Plan Name], msp.subplan_name AS [Sub Plan Name], mpl.start_time AS [JobStart], mpl.end_time AS [JobEnd], mpl.succeeded AS [JobSucceeded] FROM

如果仍在运行,我需要监控维护计划,我找到了一个旧帖子(感谢Don)来查询日志并获取作业结果,但这只会在完成后给出结果:

SELECT
    mp.name AS [MTX Plan Name],
    msp.subplan_name AS [Sub Plan Name],    
    mpl.start_time AS [JobStart],
    mpl.end_time AS [JobEnd],
    mpl.succeeded AS [JobSucceeded]
FROM
    msdb.dbo.sysmaintplan_plans mp
    INNER JOIN msdb.dbo.sysmaintplan_subplans msp ON mp.id = msp.plan_id
    INNER JOIN msdb.dbo.sysmaintplan_log mpl ON msp.subplan_id = mpl.subplan_id
        AND mpl.task_detail_id = -- Get the most recent run for this database
            (SELECT TOP 1 ld.task_detail_id 
            FROM msdb.dbo.sysmaintplan_logdetail ld
            WHERE ld.command LIKE ('%['+db_name()+']%')
            ORDER BY ld.start_time DESC)


此查询将为您提供与维护计划相关的活动/正在运行的作业。不管那里有什么,都意味着它现在正在运行

SELECT sj.name
   , sja.*
FROM msdb.dbo.sysjobactivity AS sja
INNER JOIN msdb.dbo.sysjobs AS sj ON sja.job_id = sj.job_id
WHERE sja.start_execution_date IS NOT NULL
   AND sja.stop_execution_date IS NULL
   AND sja.job_id IN (SELECT job_id FROM msdb.dbo.sysmaintplan_subplans)

如果您在sql代理作业中需要与PRTG集成的帮助,请告诉我。如果检查特定的任务历史记录,它将显示当前未完成的作业(如果有)。我知道,但我需要该查询通过监控工具自动检查,以我的情况为PRTG。谢谢jana!现在,我使用您的查询检查维护计划是否仍在运行,并使用第一个查询检查最后一个作业是否成功完成。我需要两个PRTG传感器,但不是问题!再次感谢你