创建SQL代理作业失败,没有错误

时间:2018-03-27 06:39:11

标签: c# api sql-server-2016 sql-agent-job .net-4.7

我正在尝试使用C#创建一个带有命令行步骤的SQL代理作业。 Web API正在调用一个包含该方法的类,当单步执行代码时,不会抛出任何错误,并且所有变量都有值但是在查看我的SQL实例时不会创建作业(我正在运行SQL的本地实例)服务器2016)。我在同一个班级中有两种方法可以调用; CreateJob()和AddCommandLineStep()。源代码目前看起来像这样:

班级方法

public SQLAgentJobHelper CreateJob(string JobName)
    {
        // Create Job 
        foreach (Job job in jobServer.Jobs)
        {
            if (job.Name.Equals(JobName))
            {
                job.Drop();
                break;
            }
        }
        server.ConnectionContext.BeginTransaction();
        job = new Job(jobServer, JobName);

        job.Create();
        job.ApplyToTargetServer(server.Name);

        server.ConnectionContext.CommitTransaction();           

        return this;
    }

public void AddCommandLineStep(string StepName, string Executable, string CommandLine, List<NameValue> paramList, bool isLast = false)
    {
        try
        {
            if (job == null)
                throw new Exception("First call CreateJob before adding steps");

            var jobStep = new JobStep(job, StepName);

            var paramString = CommandLine;
                paramList.ForEach(param => paramString += $"/{param.Name} {param.Value} ");
                jobStep.Command = $"\"{Executable}\" {paramString}";

            jobStep.SubSystem = AgentSubSystem.CmdExec;
            if (isLast)
                jobStep.OnSuccessAction = StepCompletionAction.QuitWithSuccess;
            else
                jobStep.OnSuccessAction = StepCompletionAction.GoToNextStep;

            jobStep.OnFailAction = StepCompletionAction.QuitWithFailure;

            jobStep.Create();

            lastJobStep = jobStep;
        }
        catch (Exception ex)
        {

        }
    } 

API调用

jobHelper.CreateJob(jobName)
jobHelper.AddCommandLineStep("Step 1", @"C:\Program Files\Microsoft SQL Server\130\DTS\Binn\DTEXEC.exe", @"C:\SSIS\CopyDataView.dtsx", Enumerable.Empty<NameValue>().ToList());

我知道空捕获并且路径将被变量替换,这只是尝试使代码按要求运行的粗略尝试。

[UPDATE]

我可以肯定地说这些方法有效,在进行单元测试时我可以在同一个SQL实例上创建一个作业。在详细了解这个问题后,我看到有大约。解决方案中有30个项目。是否有可能在另一个项目中引用了一些导致作业创建失败的dll?

1 个答案:

答案 0 :(得分:0)

API现在按预期工作!在这种情况下,有必要明确地完成API事务。使用TransactionScope命名空间及其.Complete()方法,代码现在类似于:

   using (var txscope = new TransactionScope(TransactionScopeOption.RequiresNew))
   {
            try
            {
                using (SQLAgentJobHelper jobHelper = new SQLAgentJobHelper(ServerConnection))
                { 
                   jobHelper.CreateJob(jobName)
                   jobHelper.AddCommandLineStep("Step 1", @"C:\Program Files\Microsoft SQL Server\130\DTS\Binn\DTEXEC.exe", C:\SSIS\CopyDataView.dtsx", Enumerable.Empty<NameValue>().ToList());
                }

              txscope.Complete();
              return Ok(1);
            }
            catch (Exception ex)
            {
                txscope.Dispose();
                return Ok(ex.StackTrace.ToString());
            }
    }