Compartilhar via


Definir o método de propagação de alterações de dados para artigos transacionais

Este tópico descreve como definir o método de propagação para alterações de dados para artigos transacionais no SQL Server 2012 usando SQL Server Management Studio ou Transact-SQL.

Por padrão, a replicação transacional propaga alterações para os Assinantes usando um conjunto de procedimentos armazenados para cada um dos artigos. É possível substituir esses procedimentos por procedimentos personalizados. Para obter mais informações, consulte Especificar como as alterações são propagadas para artigos transacionais.

Neste tópico

  • Antes de começar:

    Limitações e restrições

  • Para definir o método de propagação de alterações de dados para artigos transacionais, usando:

    SQL Server Management Studio

    Transact-SQL

Antes de começar

Limitações e restrições

  • É preciso tomar cuidado ao editar qualquer um dos arquivos de instantâneo gerados pela replicação. Você deve testar e oferecer suporte à lógica personalizada nos procedimentos armazenados personalizados. A Microsoft não oferece suporte a lógica personalizada.

Ícone de seta usado com o link Voltar ao Início[Top]

Usando o SQL Server Management Studio

Especifique o método de propagação na guia Propriedades da caixa de diálogo Propriedades de Artigos - <Artigo>, disponível no Assistente para Nova Publicação e na caixa de diálogo Propriedades de Publicação - <Publicação>. Para obter mais informações sobre como usar o assistente e acessar a caixa de diálogo, consulte Crie uma publicação e Visualizar e modificar as propriedades da publicação.

Para especificar o método de propagação

  1. Na página Artigos do Assistente para Nova Publicação ou na caixa de diálogo Propriedades da Publicação- <Publicação>, selecione uma tabela e clique Propriedades do Artigo.

  2. Clique em Definir as Propriedades do Artigo Realçado da Tabela.

  3. Na guia Propriedades da caixa de diálogo Propriedades de Artigo - <Artigo>, na seção Entrega de Instrução, especifique o método de propagação para cada operação usando os menus Formato de entrega de INSERT, Formato de entrega de UPDATE e Formato de entrega de DELETE.

  4. Clique em OK.

  5. Se você estiver na caixa de diálogo Propriedades de Publicação - <Publicação>, clique em OK para salvar e fechar a caixa de diálogo.

Para gerar e usar procedimentos armazenados personalizados

  1. Na página Artigos do Assistente para Nova Publicação ou na caixa de diálogo Propriedades da Publicação- <Publicação>, selecione uma tabela e clique Propriedades do Artigo.

  2. Clique em Definir as Propriedades do Artigo Realçado da Tabela.

    Na guia Propriedades da caixa de diálogo Propriedades de Artigo - <Artigo>, na seção Entrega de Instrução, selecione a sintaxe CALL no menu de formato de entrega apropriado (Formato de entrega de INSERT, Formato de entrega de UPDATE ou Formato de entrega de DELETE), depois digite o nome do procedimento a ser usado no Procedimento armazenado INSERT , Procedimento armazenado DELETE ou Procedimento armazenado UPDATE. Para obter mais informações sobre a sintaxe CALL, consulte a seção "Chamar sintaxe de procedimentos armazenados" em Especificar como as alterações são propagadas para artigos transacionais.

  3. Clique em OK.

  4. Se você estiver na caixa de diálogo Propriedades de Publicação - <Publicação>, clique em OK para salvar e fechar a caixa de diálogo.

  5. Quando o instantâneo para a publicação for gerado, incluirá o procedimento especificado na etapa anterior. Os procedimentos usarão a sintaxe CALL especificada, mas incluirão a lógica padrão utilizada pela replicação.

    Após a geração do instantâneo, vá até a pasta do instantâneo da publicação à qual esse artigo pertence e localize o arquivo .sch com nome idêntico ao do artigo. Abra esse arquivo usando o Bloco de Notas ou outro editor de textos, localize o comando CREATE PROCEDURE para os procedimentos de inserir, atualizar ou excluir e edite a definição do procedimento para fornecer todas as lógicas de personalização para a propagação das alterações de dados. Se o instantâneo for regenerado, será preciso recriar o procedimento personalizado.

Ícone de seta usado com o link Voltar ao Início[Top]

Usando Transact-SQL

A replicação transacional permite que você controle como as alterações são propagadas do Publicador para os Assinantes, e esse método de propagação pode ser definido programaticamente quando um artigo é criado e posteriormente alterado usando procedimentos armazenados de replicação.

ObservaçãoObservação

Você pode especificar um método de propagação diferente para cada tipo de operação DML (linguagem de manipulação de dados) - inserir, atualizar ou deletar - que ocorra em uma linha de um dado publicado.

Para obter mais informações, consulte Especificar como as alterações são propagadas para artigos transacionais.

Para criar um artigo que use comandos Transact-SQL para propagar alterações de dados

  • No Publicador do banco de dados de publicação, execute sp_addarticle. Especifique o nome da publicação à qual o artigo pertence para @publication, um nome para o artigo para @article, o objeto de banco de dados a ser publicado para @source_object e um valor de SQL para pelo menos um dos seguintes parâmetros:

    • @ins_cmd - controla a replicação dos comandos INSERT.

    • @upd_cmd - controla a replicação dos comandos UPDATE.

    • @del_cmd - controla a replicação dos comandos DELETE.

    ObservaçãoObservação

    Ao especificar um valor de SQL para qualquer um dos parâmetros acima, os comandos desse tipo serão replicados para o Assinante como o comando Transact-SQL apropriado.

    Para obter mais informações, consulte Defina um Artigo.

Para criar um artigo que não propague alterações de dados

  • No Publicador do banco de dados de publicação, execute sp_addarticle. Especifique o nome da publicação à qual o artigo pertence para @publication, um nome para o artigo para @article, o objeto de banco de dados a ser publicado para @source_object e um valor de NONE para pelo menos um dos seguintes parâmetros:

    • @ins_cmd - controla a replicação dos comandos INSERT.

    • @upd_cmd - controla a replicação dos comandos UPDATE.

    • @del_cmd - controla a replicação dos comandos DELETE.

    ObservaçãoObservação

    Ao especificar um valor de NONE para qualquer um dos parâmetros acima, os comandos desse tipo não serão replicados para o Assinante.

    Para obter mais informações, consulte Defina um Artigo.

Para criar um artigo com procedimentos armazenados personalizados modificados pelo usuário

  1. No Publicador do banco de dados de publicação, execute sp_addarticle. Especifique o nome da publicação à qual o artigo pertence para @publication, um nome para o artigo para @article, o objeto de banco de dados a ser publicado para @source_object, um valor para o bitmask @schema_option que contém o valor 0x02 (habilita geração automática de procedimentos armazenados personalizados) e pelo menos um dos seguintes parâmetros:

    • @ins_cmd - especifica um valor de CALL sp_MSins_article_name, onde article_name é o valor especificado para @article.

    • @del_cmd - especifica um valor de CALL sp_MSdel_article_name ou XCALL sp_MSdel_article_name, onde article_name é o valor especificado para @article.

    • @upd_cmd - especifica um valor de SCALL sp_MSupd_article_name, CALL sp_MSupd_article_name, XCALL sp_MSupd_article_name ou MCALL sp_MSupd_article_name, onde article_name é o valor especificado para @article.

    ObservaçãoObservação

    Para cada um dos parâmetros de comando acima, você pode especificar seu próprio nome para os procedimentos armazenados que a replicação gera.

    ObservaçãoObservação

    Para obter mais informações sobre sintaxe CALL, SCALL, XCALL e MCALL, consulte Especificar como as alterações são propagadas para artigos transacionais.

    Para obter mais informações, consulte Defina um Artigo.

  2. Após a geração do instantâneo, vá até a pasta do instantâneo da publicação à qual esse artigo pertence e localize o arquivo .sch com nome idêntico ao do artigo. Abra esse arquivo usando Notepad.exe, localize o comando CREATE PROCEDURE para os procedimentos armazenados de inserir, atualizar ou excluir, e edite a definição do procedimento para fornecer as lógicas de personalização para a propagação das alterações de dados. Para obter mais informações, consulte Especificar como as alterações são propagadas para artigos transacionais.

Para criar um artigo com script personalizado nos procedimentos armazenados personalizados para propagar alterações de dados

  1. No Publicador do banco de dados de publicação, execute sp_addarticle. Especifique o nome da publicação à qual o artigo pertence para @publication, um nome para o artigo para @article, o objeto de banco de dados a ser publicado para @source_object, um valor para o bitmask @schema_option que contém o valor 0x02 (habilita geração automática de procedimentos armazenados personalizados) e pelo menos um dos seguintes parâmetros:

    • @ins_cmd - especifica um valor de CALL sp_MSins_article_name, onde article_name é o valor especificado para @article.

    • @del_cmd - especifica um valor de CALL sp_MSdel_article_name ou XCALL sp_MSdel_article_name, onde article_name é o valor especificado para @article.

    • @upd_cmd - especifica um valor de SCALL sp_MSupd_article_name, CALL sp_MSupd_article_name, XCALL sp_MSupd_article_name, MCALL sp_MSupd_article_name, onde article_name é o valor especificado para @article.

    ObservaçãoObservação

    Para cada um dos parâmetros de comando acima, você pode especificar seu próprio nome para os procedimentos armazenados que a replicação gera.

    ObservaçãoObservação

    Para obter mais informações sobre sintaxe CALL, SCALL, XCALL e MCALL, consulte Especificar como as alterações são propagadas para artigos transacionais.

    Para obter mais informações, consulte Defina um Artigo.

  2. No Publicador do banco de dados de publicação, use a instrução ALTER PROCEDURE para editar sp_scriptpublicationcustomprocs de maneira que retorne um script CREATE PROCEDURE para os procedimentos armazenados personalizados de inserir, atualizar e deletar. Para obter mais informações, consulte Especificar como as alterações são propagadas para artigos transacionais.

Para alterar o método de propagar alterações para um artigo existente

  1. No Publicador do banco de dados de publicação, execute sp_changearticle. Especifique @publication, @article, um valor de ins_cmd, upd_cmd ou del_cmd para @property e o método de propagação apropriado para @value.

  2. Repita a etapa 1 para cada método de propagação a ser alterado.

Ícone de seta usado com o link Voltar ao Início[Top]

Consulte também

Conceitos

Especificar como as alterações são propagadas para artigos transacionais

Criar, modificar e excluir publicações e artigos (Replicação)