簡體   English   中英

SQL Server代理作業的最新兩個狀態

[英]The latest two status of sql server agent jobs

我需要進行查詢以獲取sql服務器代理作業的狀態。

棘手的部分是,我都希望作業的上次失敗時間(如果有的話)以及上次執行成功的時間-可能嗎?

到目前為止,我只能獲得作業的最后一次成功運行或最后一次失敗的運行。

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

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM