Criar uma etapa de trabalho CmdExec
Este tópico descreve como criar e definir uma etapa de trabalho do Microsoft SQL Server Agent no SQL Server 2012 que usa um programa executável ou comando do sistema operacional usando SQL Server Management Studio, Transact-SQL ou SQL Server Management Objects.
Neste tópico
Antes de começar:
Segurança
Para criar uma etapa de trabalho CmdExec, usando:
SQL Server Management Studio
Transact-SQL
SQL Server Management Objects
Antes de começar
Segurança
Por padrão, só membros da função de servidor fixa sysadmin podem criar etapas de trabalho CmdExec. Essas etapas de trabalho são executadas no contexto da conta de serviço do SQL Server Agent, a menos que o usuário de sysadmin crie uma conta proxy. Usuários que não sejam membros da função sysadmin poderão criar etapas de trabalho CmdExec se tiverem acesso à conta proxy de CmdExec.
Permissões
Para obter informações detalhadas, consulte Implementar a segurança do SQL Server Agent.
[Top]
Usando o SQL Server Management Studio
Para criar uma etapa de trabalho CmdExec
No Pesquisador de Objetos, conecte-se a uma instância do Mecanismo de Banco de Dados do SQL Server e a expanda.
Expanda SQL Server Agent, crie um novo trabalho ou clique com o botão direito do mouse em um trabalho existente e, em seguida, clique em Propriedades.
Na caixa de diálogo Propriedades do Trabalho, clique na página Etapas e, em seguida, em Nova.
Na caixa de diálogo Nova Etapa de Trabalho, digite o Nome da etapa de trabalho.
Na lista Tipo, escolha Sistema operacional (CmdExec).
Na lista Executar como, selecione a conta proxy com as credenciais que o trabalho usará. Por padrão, etapas de trabalho CmdExec são executadas no contexto da conta do serviço do SQL Server Agent .
Na caixa Código de saída do processo de um comando bem sucedido, insira um valor de 0 a 999999.
Na caixa Comando, digite o comando de sistema operacional ou programa executável. Consulte "Usando Transact T-SQL para obter um exemplo.
Clique na página Avançado para definir opções para a etapa de trabalho, como a ação a tomar em caso de êxito ou falha da etapa, quantas vezes o SQL Server Agent deve tentar executar a etapa e o arquivo onde o SQL Server Agent pode gravar a saída da etapa. Somente membros da função de servidor fixa sysadmin podem gravar a saída de etapas de trabalho em um arquivo do sistema operacional.
[Top]
Usando Transact-SQL
Para criar uma etapa de trabalho CmdExec
No Pesquisador de Objetos, conecte-se a uma instância do Mecanismo de Banco de Dados.
Na barra Padrão, clique em Nova Consulta.
Copie e cole o exemplo a seguir na janela de consulta e clique em Executar.
-- creates a job step that that uses CmdExec USE msdb; GO EXEC sp_add_jobstep @job_name = N'Weekly Sales Data Backup', @step_name = N'Set database to read only', @subsystem = N'CMDEXEC', @command = C:\clickme_scripts\SQL11\PostBOLReorg GetHsX.exe', @retry_attempts = 5, @retry_interval = 5 ; GO
Para obter mais informações, consulte sp_add_jobstep (Transact-SQL).
[Top]
Usando o SQL Server Management Objects
Para criar uma etapa de trabalho CmdExec
Use a classe JobStep usando uma linguagem de programação que você escolher, como o Visual Basic, Visual C# ou PowerShell. Para obter mais informações, consulte SQL Server Management Objects (SMO).
[Top]