Obtenha uma lista de trabalhos do SQL Server Agent

55

Eu tenho uma seleção extensa deles para adicionar a uma planilha e não quero passar manualmente. Qual é o comando T-SQL para gerar uma lista de trabalhos do SQL Server Agent?

alimack
fonte

Respostas:

65

Em cada servidor, você pode consultar a tabela sysjobs no msdb. Por exemplo:

SELECT job_id, [name] FROM msdb.dbo.sysjobs;
K. Brian Kelley
fonte
Obrigado, acho que você acabou de me dar um soco para receber o prêmio!
Alimack
19
-- List of all the jobs currently running on server
SELECT
     job.job_id,
     notify_level_email,
     name,
     enabled,
     description,
     step_name,
     command,
     server,
     database_name
FROM
    msdb.dbo.sysjobs job
INNER JOIN 
    msdb.dbo.sysjobsteps steps        
ON
    job.job_id = steps.job_id
WHERE
    job.enabled = 1 -- remove this if you wish to return all jobs
robyaw
fonte
Você pode formatar o SQL?
Frank V
4

Aqui está minha contribuição - também obtém o nome da categoria e filtra os trabalhos do servidor de relatório.

SELECT  sysjobs.name 'Job Name',
        syscategories.name 'Category',
        CASE [description]
          WHEN 'No Description available.' THEN ''
          ELSE [description]
        END AS 'Description'
FROM    msdb.dbo.sysjobs
        INNER JOIN msdb.dbo.syscategories ON msdb.dbo.sysjobs.category_id = msdb.dbo.syscategories.category_id
WHERE   syscategories.name <> 'Report Server'
ORDER BY sysjobs.name 
Sam
fonte
2

Meu chefe realmente resolveu o que eu estava procurando - isso me deu a lista que eu estava procurando.

USE o nome do msdb SELECT FROM sysjobs

alimack
fonte