Partilhar via


sp_dropsubscription (Transact-SQL)

Descarta assinaturas para um artigo específico, publicação ou conjunto de assinaturas no Publicador. Esse procedimento armazenado é executado no Publicador, no banco de dados de publicação.

Ícone de vínculo de tópicoConvenções de sintaxe Transact-SQL

Sintaxe

sp_dropsubscription [ [ @publication= ] 'publication' ]
    [ , [ @article= ] 'article' ]
        , [ @subscriber= ] 'subscriber'
    [ , [ @destination_db= ] 'destination_db' ]
    [ , [ @ignore_distributor = ] ignore_distributor ]
    [ , [ @reserved= ] 'reserved' ]

Argumentos

  • [ [ @publication= ] 'publication'
    É o nome da publicação associada. publication is sysname, com um padrão NULL. Se for all, todas as assinaturas para todas as publicações do Assinante especificado serão canceladas. publication é um parâmetro exigido.

  • [ [ @article= ] 'article'
    É o nome do artigo. article é sysname, com um valor padrão NULL. Se for all, assinaturas para todos os artigos de cada publicação especificada e Assinante serão descartadas. Use all para publicações que permitam atualização imediata.

  • [ @subscriber= ] 'subscriber'
    É o nome do Assinante que terá suas assinaturas descartadas. subscriber é sysname, sem padrão. Se for all, todas as assinaturas para todos o Assinantes serão descartadas.

  • [ [ @destination_db= ] 'destination_db'
    É o nome do banco de dados de destino. destination_db é sysname, com um padrão de NULL. Se for NULL, todas as assinaturas daquele Assinante serão descartadas.

  • [ @ignore_distributor = ] ignore_distributor
    Identificado apenas para fins informativos. Não há suporte. A compatibilidade futura não está garantida.

  • [ @reserved= ] 'reserved'
    Identificado apenas para fins informativos. Não há suporte. A compatibilidade futura não está garantida.

Valores de código de retorno

0 (êxito) ou 1 (falha)

Comentários

sp_dropsubscription é usado em replicação de instantâneo e replicação transacional.

Se você descartar a assinatura de um artigo em uma publicação de sincronização imediata, não poderá adicioná-la novamente, exceto se descartar as assinaturas em todos os artigos de publicação e os adicionar novamente, todos de uma vez.

Exemplo

-- This script uses sqlcmd scripting variables. They are in the form
-- $(MyVariable). For information about how to use scripting variables  
-- on the command line and in SQL Server Management Studio, see the 
-- "Executing Replication Scripts" section in the topic
-- "Programming Replication Using System Stored Procedures".

-- This batch is executed at the Publisher to remove 
-- a pull or push subscription to a transactional publication.
DECLARE @publication AS sysname;
DECLARE @subscriber AS sysname;
SET @publication = N'AdvWorksProductTran';
SET @subscriber = $(SubServer);

USE [AdventureWorks]
EXEC sp_dropsubscription 
  @publication = @publication, 
  @article = N'all',
  @subscriber = @subscriber;
GO

Permissões

Somente membros da função de servidor fixa sysadmin ou da função de banco de dados fixa db_owner ou o usuário que criou a assinatura podem executar sp_dropsubscription.