easeyeah

SQLSERVER 2008 中删除作业时遇到无法删除

解决办法:

USE [msdb]
DECLARE @job_name VARCHAR(100)
SET @job_name = N\'JobName\'

--注:jobName为维护计划对应的jobName
--删除在计划里面的日志
DELETE
    sysmaintplan_log
FROM
    sysmaintplan_subplans AS subplans
    INNER JOIN sysjobs_view AS syjobs ON subplans.job_id = syjobs.job_id
    INNER JOIN sysmaintplan_log ON subplans.subplan_id =sysmaintplan_log.subplan_id
WHERE
    (syjobs.name = @job_name)

--删除代理的作业
DELETE
    sysjobschedules FROM sysjobs_view v
    INNER JOIN sysjobschedules o ON v.job_id=o.job_id
WHERE
    v.name=@job_name

--删除子计划
DELETE
    sysmaintplan_subplans
FROM
    sysmaintplan_subplans AS subplans    
    INNER JOIN sysjobs_view AS syjobs ON subplans.job_id = syjobs.job_id
WHERE
    (syjobs.name = @job_name)

--删除作业
DELETE FROM msdb.dbo.sysjobs_view WHERE name = @job_name

 

分类:

技术点:

相关文章:

  • 2021-11-04
  • 2021-12-12
  • 2021-09-26
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-02-26
猜你喜欢
  • 2022-12-23
  • 2022-03-10
  • 2022-12-23
  • 2021-06-18
  • 2021-06-12
  • 2021-11-01
  • 2021-11-03
相关资源
相似解决方案