Sqlserver
 sql >> डेटाबेस >  >> RDS >> Sqlserver

संग्रहीत कार्यविधि से SQL सर्वर एजेंट कार्य निष्पादित करना और कार्य परिणाम लौटाना

आप सभी लोगों के लिए जिन्हें अनुमति नहीं है OPENROWSET . का उपयोग करने के लिए आदेश, यह मदद कर सकता है। मुझे अपने समाधान की शुरुआत यहां मिली:

http://social.msdn.microsoft.com/Forums/en-US/89659729-fea8-4df0-8057-79e0a437b658/dynamically-checking-job-status-with-tsql

यह इस तथ्य पर निर्भर करता है कि msdb.dbo.sysjobactivity . के कुछ कॉलम किसी न किसी तरह से कार्य समाप्त होने के बाद तालिका पहले पॉप्युलेट हो जाती है।

-- 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

WHILE-loop को कितने समय तक चलने की अनुमति है, इसके लिए आप कुछ जांच कर सकते हैं। मैंने उस हिस्से को उदाहरण से बाहर रखना चुना।

निकास कोड आदि के लिए Microsoft मार्गदर्शन:http://technet.microsoft.com /en-us/library/ms174997.aspx



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. SQL सर्वर 2005 पर SQL Server 2008 के लाभ?

  2. SQL सर्वर में एक अस्थायी तालिका बनाएँ

  3. SQL सर्वर 2017 बैकअप -3

  4. एक सहयोगी तालिका का उपयोग करने के बजाय झंडे को बिटमास्क के रूप में स्टोर करना बेहतर कब होता है?

  5. एसक्यूएल सर्वर टेबल में कॉलम को नल से नॉट नल में कैसे बदलें - एसक्यूएल सर्वर / टी-एसक्यूएल ट्यूटोरियल पार्ट 52