微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

sql-server – 获取上次成功运行的日期?

我有一个执行存储过程的步骤作业.我想获得上次成功执行作业的日期,以便我可以更新delta而不是整个数据集.

现在我的作业设置每天运行一次,所以我有一个认参数,如果它为null我将它设置为GETDATE() – 1所以我仍然在更新delta但是我想做的是设置上次成功执行作业的日期.

exec dbo.usp_UpdateFrom @LastSuccessfulExecutionTime

目前的程序是这样的

CREATE PROCEDURE dbo.usp_UpdateFrom
    @FromDate datetime = NULL --would like to pass last successful execution time of the job
AS
    IF @FromDate IS NULL
        SET @FromDate = GETDATE() - 1

    -- do stuff
END

解决方法

您想要的表是msdb中的 sysjobssysjobhistory.虽然被警告! sql Server只维护一定数量的记录,因此如果作业太多且历史记录不够大,最终将没有历史记录.

以下代码检索给定作业名称的job_id,并查询历史记录表以查找上次成功完成的运行(即步骤0,状态1).如您所见,您必须将运行时间转换回日期,因为sql Server将其存储在两个int列中:

DECLARE @job_id binary(16)
SELECT @job_id = job_id FROM msdb.dbo.sysjobs WHERE (name = N'YourJobName')

SELECT TOP 1
    CONVERT(DATETIME,RTRIM(run_date))
    + ((run_time / 10000 * 3600) 
    + ((run_time % 10000) / 100 * 60) 
    + (run_time % 10000) % 100) / (86399.9964) AS run_datetime,*
FROM
    msdb..sysjobhistory sjh
WHERE
    sjh.step_id = 0 
    AND sjh.run_status = 1 
    AND sjh.job_id = @job_id
ORDER BY
    run_datetime DESC

原文地址:https://www.jb51.cc/mssql/79120.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐