Планирование пакета служб SSIS с использованием C # - PullRequest
2 голосов
/ 04 марта 2012

Что я хочу сделать, это запланировать пакет служб SSIS, используя C #. отсутствует часть, как сообщить агенту, что это расписание для пакета служб SSIS "X", вот мой код:

Server srv = new Server();

//Define an Operator object variable by supplying the Agent (parent JobServer object) and the name in the constructor. 
Operator op = new Operator(srv.JobServer, "AC_Operator") { NetSendAddress = "Network1_PC" };

//Create the operator on the instance of SQL Server Agent. 
op.Create();

//Define a Job object variable by supplying the Agent and the name arguments in the constructor and setting properties. 
Job jb = new Job(srv.JobServer, "AC_Job");

//Specify which operator to inform and the completion action. 
jb.OperatorToNetSend = "AC_Operator";
jb.NetSendLevel = CompletionAction.Always;

//Create the job on the instance of SQL Server Agent. 
jb.Create();

//Define a JobStep object variable by supplying the parent job and name arguments in the constructor. 
JobStep jbstp = new JobStep(jb, "AC_Job_Step");
jbstp.OnSuccessAction = StepCompletionAction.QuitWithSuccess;
jbstp.OnFailAction = StepCompletionAction.QuitWithFailure;

//Create the job step on the instance of SQL Agent. 
jbstp.Create();

//Define a JobSchedule object variable by supplying the parent job and name arguments in the constructor. 

JobSchedule jbsch = new JobSchedule(jb, "AC_Job_Schedule");

//Set properties to define the schedule frequency, and duration. 
jbsch.FrequencyTypes = FrequencyTypes.Daily;
jbsch.FrequencySubDayTypes = FrequencySubDayTypes.Minute;
jbsch.FrequencySubDayInterval = 30;
TimeSpan ts1 = new TimeSpan(9, 0, 0);
jbsch.ActiveStartTimeOfDay = ts1;

TimeSpan ts2 = new TimeSpan(17, 0, 0);
jbsch.ActiveEndTimeOfDay = ts2;
jbsch.FrequencyInterval = 1;

DateTime d = new DateTime(2003, 1, 1);
jbsch.ActiveStartDate = d;

//Create the job schedule on the instance of SQL Agent. 
jbsch.Create();

Спасибо за ваше время.

1 Ответ

1 голос
/ 05 марта 2012

Что вам нужно сделать, это установить Подсистему * шага задания и затем создать Команду .Сравнивая сгенерированный код .NET с заданием, созданным агентом SQL, я заметил только одно отличие - присваивание свойства DatabaseName , поэтому я также установил его.

Вы также, несомненно, захотите взглянуть на dtexec , чтобы выяснить, как настроить и вызвать ваш пакет, или вы можете обмануть, как я, и использовать dtexecui или агент для создания SET.и другие команды, а затем вставьте их в качестве исходной команды.

        //Define a JobStep object variable by supplying the parent job and name arguments in the constructor. 
        JobStep jbstp = new JobStep(jb, "AC_Job_Step");
        jbstp.OnSuccessAction = StepCompletionAction.QuitWithSuccess;
        jbstp.OnFailAction = StepCompletionAction.QuitWithFailure;

        string command = string.Empty;
        command = @"/FILE ""C:\sandbox\SSISHackAndSlash2008\SSISHackAndSlash2008\EzAPI_Recipe01.dtsx""  /CHECKPOINTING OFF /REPORTING E";
        jbstp.SubSystem = AgentSubSystem.Ssis;
        jbstp.DatabaseName = "master";
        jbstp.Command = command;

        //Create the job step on the instance of SQL Agent. 
        jbstp.Create();
...