Dành cho tất cả các bạn, những người không được phép để sử dụng OPENROWSET lệnh, điều này có thể hữu ích. Tôi đã tìm thấy điểm khởi đầu cho giải pháp của mình ở đây:
Điều này dựa trên thực tế là một số cột của msdb.dbo.sysjobactivity bảng đầu tiên được điền sau khi công việc kết thúc theo cách này hay cách khác.
-- Start job
DECLARE @job_name NVARCHAR(MAX) = 'JobName'
EXEC msdb.dbo.sp_start_job @job_name = @job_name
-- Wait for job to finish
DECLARE @job_history_id AS INT = NULL
WHILE @time_constraint = @ok
BEGIN
SELECT TOP 1 @job_history_id = activity.job_history_id
FROM msdb.dbo.sysjobs jobs
INNER JOIN msdb.dbo.sysjobactivity activity ON activity.job_id = jobs.job_id
WHERE jobs.name = @job_name
ORDER BY activity.start_execution_date DESC
IF @job_history_id IS NULL
BEGIN
WAITFOR DELAY '00:00:10'
CONTINUE
END
ELSE
BREAK
END
-- Check exit code
SELECT history.run_status
FROM msdb.dbo.sysjobhistory history
WHERE history.instance_id = @job_history_id
Bạn có thể muốn kiểm tra xem vòng lặp WHILE được phép chạy trong bao lâu. Tôi đã chọn không để phần đó ra khỏi ví dụ.
Hướng dẫn của Microsoft về mã thoát, v.v.: http://technet.microsoft.com /en-us/library/ms174997.aspx