sql >> Base de Datos >  >> RDS >> Sqlserver

¿Cómo puedo saber el estado de un trabajo?

Me gustaría señalar que ninguno de los T-SQL en esta página funcionará precisamente porque ninguno de ellos se une a las syssessions table para obtener solo la sesión actual y, por lo tanto, podría incluir falsos positivos.

Vea esto como referencia:¿Qué significa tener trabajos con una fecha de finalización nula?

También puede validar esto analizando la sp_help_jobactivity procedimiento en msdb .

Me doy cuenta de que este es un mensaje antiguo en SO, pero encontré este mensaje solo parcialmente útil debido al problema.

SELECT
    job.name, 
    job.job_id, 
    job.originating_server, 
    activity.run_requested_date, 
    DATEDIFF( SECOND, activity.run_requested_date, GETDATE() ) as Elapsed
FROM 
    msdb.dbo.sysjobs_view job
JOIN
    msdb.dbo.sysjobactivity activity
ON 
    job.job_id = activity.job_id
JOIN
    msdb.dbo.syssessions sess
ON
    sess.session_id = activity.session_id
JOIN
(
    SELECT
        MAX( agent_start_date ) AS max_agent_start_date
    FROM
        msdb.dbo.syssessions
) sess_max
ON
    sess.agent_start_date = sess_max.max_agent_start_date
WHERE 
    run_requested_date IS NOT NULL AND stop_execution_date IS NULL