确定今天第一次工作是否正在运行

时间:2015-12-01 09:39:52

标签: sql sql-server sql-agent-job

每天第一次运行sql job时,我需要更新一些列。我的工作将从每天凌晨4点开始。

所以我可以这样做:

IF(CONVERT(VARCHAR(8),GETDATE(),108) = '04:00:00')
BEGIN
 // Update
END

但是,如果由于某种原因我的工作不能在凌晨4点运行。如何重置这些列。任何想法,建议,帮助。

我的要求如下: 我的系统从我的最终用户那里获取任务。此职位需要根据员工的能力将这些任务分配给员工。所以,我有一张EmpId表,MaxAssignments(可以在一天内分配最多任务数)& AssignmentsCount(已分配的任务数)列。每天第一次运行时,我想将此“AssignmentsCount”值设置为0。

1 个答案:

答案 0 :(得分:0)

您应该能够在工作步骤中使用与下面类似的代码。 SQL语句分解为注释以供解释。为简洁起见,您可以将它们组合在一起,或者甚至将其组合成一个单独的标量函数,该函数接受作业标识符,并在第一次运行时返回true或false。

DECLARE @job_id uniqueidentifier
DECLARE @run_requested_date DATETIME
DECLARE @first_run_today DATETIME

-- Use Tokens in Job Steps
-- https://msdn.microsoft.com/en-us/library/ms175575.aspx
-- Within your SQL Agent job step you can use this tokenized
-- statement to get the job_id.
--SET @job_id = CONVERT(uniqueidentifier, $(ESCAPE_NONE(JOBID)))

-- You can use this statement instead, but it will break if the
-- job name is changed and you forget to update the [name]
-- parameter below ('Test' is the job name in this example)
SELECT @job_id = job_id
  FROM msdb.dbo.sysjobs
 WHERE name = 'Test'

-- Debug statement
PRINT 'job_id = ' + CONVERT(VARCHAR(255), @job_id)

-- Get the scheduled run time for this currently
-- executing job (can alternatively use the
-- start_execution_date column instead)
SELECT @run_requested_date = run_requested_date 
  FROM msdb.dbo.sysjobactivity 
 WHERE job_id = @job_id

-- Debug statement
PRINT 'run_requested_date = ' + CONVERT(VARCHAR(50), @run_requested_date, 126)

-- For the given job, find any job history row that
-- was successfully execute at an earlier time on 
-- this date.
--
-- The msdb.dbo.agent_datetime() function is a built-in
-- function that will values from the separate date and time
-- columns in the job history table and convert them to a
-- single datetime value.
SELECT @first_run_today = msdb.dbo.agent_datetime(run_date, run_time) 
  FROM msdb.dbo.sysjobhistory 
 WHERE JOB_ID = @job_id 
   AND run_status = 1 -- Successful
   AND run_date = CONVERT(VARCHAR(10), @run_requested_date, 112) -- YYYYMMDD format compare
   AND msdb.dbo.agent_datetime(run_date, run_time) < @run_requested_date

-- Debug statement
PRINT 'first_run_today = ' + CONVERT(VARCHAR(50), @first_run_today, 126)

-- If the first_run_today variable is null then
-- that means for the current date we did not
-- any successful runs of this job before now.
IF @first_run_today IS NULL
BEGIN
  PRINT 'This *is* the first run.'
  -- First run statements go here.
END
ELSE
BEGIN
  PRINT 'This is *not* the first run.'
  -- Non first run statements go here.
END