0
以下のスクリプトを使用して、エージェントジョブのJob_stateを取得しています。Find Job_State of SQLエージェントジョブ - SQL Server
ジョブが稼働しているときにjob_state = 1が正常に返されます。
しかし、他のすべての場合(失敗/成功/キャンセル)のためには、私はそれが成功/失敗したかキャンセルされたかどうかを判断できるように、私は正確なたjob_stateを取得できます(そのアイドルを意味する)JOB_STATUS 4
を返します。これまで
私のスクリプトは:
DECLARE @xp_results TABLE
(
job_id UNIQUEIDENTIFIER NOT NULL ,
last_run_date INT NOT NULL ,
last_run_time INT NOT NULL ,
next_run_date INT NOT NULL ,
next_run_time INT NOT NULL ,
next_run_schedule_id INT NOT NULL ,
requested_to_run INT NOT NULL ,
request_source INT NOT NULL ,
request_source_id SYSNAME COLLATE database_default NULL ,
running INT NOT NULL ,
current_step INT NOT NULL ,
current_retry_attempt INT NOT NULL ,
job_state INT NOT NULL
)
SET NOCOUNT ON
INSERT INTO @xp_results
EXEC master.dbo.xp_sqlagent_enum_jobs 1, ''
DECLARE @jobs TABLE
(
rownum INT IDENTITY(1, 1)
PRIMARY KEY
NOT NULL ,
job_id UNIQUEIDENTIFIER NOT NULL
)
SELECT name,job_state
FROM @xp_results rj
INNER JOIN msdb.dbo.sysjobs sj ON sj.job_id = rj.job_id