Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/azure/13.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Sql server sql server代理作业的最新两种状态_Sql Server_Sql Agent Job - Fatal编程技术网

Sql server sql server代理作业的最新两种状态

Sql server sql server代理作业的最新两种状态,sql-server,sql-agent-job,Sql Server,Sql Agent Job,我需要进行一个查询,以获取sql server代理作业的状态 棘手的是,我都想知道作业上次失败的时间(如果有)和上次成功运行的时间——这可能吗 到目前为止,我只能获得作业的最后一次成功运行或最后一次失败运行 SELECT job.name ,jobh.run_date ,DATEADD(HOUR, (jobh.run_time / 1000000) % 100, DATEADD(MINUTE, (jobh.run_time / 10000) % 100, DATEADD(SECOND, (

我需要进行一个查询,以获取sql server代理作业的状态

棘手的是,我都想知道作业上次失败的时间(如果有)和上次成功运行的时间——这可能吗

到目前为止,我只能获得作业的最后一次成功运行或最后一次失败运行

SELECT 
job.name
,jobh.run_date 
,DATEADD(HOUR, (jobh.run_time / 1000000) % 100, 
DATEADD(MINUTE, (jobh.run_time / 10000) % 100,
DATEADD(SECOND, (jobh.run_time / 100) % 100,
DATEADD(MILLISECOND, (jobh.run_time % 100) * 10, 
cast('00:00:00' as TIME(0)))))) AS 'tidspunkt'
,jobh.run_duration
FROM msdb.dbo.sysjobhistory jobh
JOIN [msdb].[dbo].[sysjobs] job ON jobh.job_id = job.job_id
WHERE jobh.step_id = 0
AND jobh.message LIKE '%failed%'
AND (jobh.run_date = CONVERT(VARCHAR, GETDATE(), 112) OR jobh.run_date =    CONVERT(VARCHAR, DATEADD(DAY, -1, GETDATE()), 112) )
AND job.name = 'UpdateCPR'
ORDER BY jobh.run_date DESC, jobh.run_time DESC

只要换一条线

AND jobh.message LIKE '%failed%'
…到下面

AND (jobh.message LIKE '%failed%' OR jobh.message LIKE '%succeeded%')
您将得到多行。如果您愿意,您可以根据相似的结果将其分组,并从两者中选择TOP 1以在一行中检索它

;WITH jobRuns AS (
    SELECT
        job.job_id,
        job.name,
        jobh.run_time,
        jobh.run_duration,
        execStatus
    FROM msdb.dbo.sysjobhistory jobh
    JOIN msdb.dbo.sysjobs job 
        ON jobh.job_id = job.job_id
    CROSS APPLY(
        SELECT execStatus = CASE 
            WHEN jobh.message LIKE '%failed%' THEN 0 
            WHEN jobh.message LIKE '%succeeded%' THEN 1 END) ext
    WHERE 
        jobh.step_id = 0
        and job.name LIKE '%testjob%'
    /*GROUP BY
        job.job_id,
        job.name,
        jobh.run_time,
        execStatus*/)
,lastRuns AS (
    SELECT TOP 1
        jobRuns.job_id,
        jobRuns.name,
        run_time_failed = failed.run_time,
        run_duration_failed = failed.run_duration,
        run_time_succeeded = success.run_time,
        run_duration_succeeded = success.run_duration
    FROM jobRuns
    CROSS APPLY(
        SELECT TOP 1 run_time, run_duration
        FROM jobRuns
        WHERE execStatus = 0
        ORDER BY run_time DESC) failed
    CROSS APPLY(
        SELECT TOP 1 run_time, run_duration
        FROM jobRuns
        WHERE execStatus = 1
        ORDER BY run_time DESC) success
)
SELECT * 
FROM lastRuns
编辑

使用此选项可在一行中获取失败和成功信息

;WITH jobRuns AS (
    SELECT
        job.job_id,
        job.name,
        jobh.run_time,
        jobh.run_duration,
        execStatus
    FROM msdb.dbo.sysjobhistory jobh
    JOIN msdb.dbo.sysjobs job 
        ON jobh.job_id = job.job_id
    CROSS APPLY(
        SELECT execStatus = CASE 
            WHEN jobh.message LIKE '%failed%' THEN 0 
            WHEN jobh.message LIKE '%succeeded%' THEN 1 END) ext
    WHERE 
        jobh.step_id = 0
        and job.name LIKE '%testjob%'
    /*GROUP BY
        job.job_id,
        job.name,
        jobh.run_time,
        execStatus*/)
,lastRuns AS (
    SELECT TOP 1
        jobRuns.job_id,
        jobRuns.name,
        run_time_failed = failed.run_time,
        run_duration_failed = failed.run_duration,
        run_time_succeeded = success.run_time,
        run_duration_succeeded = success.run_duration
    FROM jobRuns
    CROSS APPLY(
        SELECT TOP 1 run_time, run_duration
        FROM jobRuns
        WHERE execStatus = 0
        ORDER BY run_time DESC) failed
    CROSS APPLY(
        SELECT TOP 1 run_time, run_duration
        FROM jobRuns
        WHERE execStatus = 1
        ORDER BY run_time DESC) success
)
SELECT * 
FROM lastRuns

在上面的查询中,你将如何将失败和成功状态一行一组地显示出来?你就是那个人!非常感谢!