sp_dropdistributor (Transact-SQL)

Aplica-se a:SQL ServerInstância Gerenciada de SQL do Azure

Desinstala o Distribuidor. Esse procedimento armazenado é executado no Distribuidor ou em qualquer banco de dados, exceto no banco de dados de distribuição.

Convenções de sintaxe de Transact-SQL

Sintaxe

sp_dropdistributor
    [ [ @no_checks = ] no_checks ]
    [ , [ @ignore_distributor = ] ignore_distributor ]
[ ; ]

Argumentos

@no_checks [ = ] no_checks

Indica se os objetos dependentes devem ser verificados antes da remoção do Distribuidor. @no_checks é bit, com um padrão de 0.

  • Se 0, verifica se todos os objetos de publicação e distribuição foram descartados, sp_dropdistributor além do Distribuidor.

  • Se 1, sp_dropdistributor descarta todos os objetos de publicação e distribuição antes de desinstalar o distribuidor.

@ignore_distributor [ = ] ignore_distributor

Indica se esse procedimento armazenado será executado sem se conectar ao Distribuidor. @ignore_distributor é bit, com um padrão de 0.

  • Se 0, sp_dropdistributor conecta-se ao Distribuidor e remove todos os objetos de replicação. Se sp_dropdistributor não for possível conectar-se ao Distribuidor, o procedimento armazenado falhará.

  • Se 1, nenhuma conexão for feita com o Distribuidor e os objetos de replicação não forem removidos. Essa opção será usada se o Distribuidor estiver sendo desinstalado ou estiver permanentemente offline. Os objetos deste Publicador no Distribuidor não serão removidos até que o Distribuidor seja reinstalado em algum momento futuro.

Valores do código de retorno

0 (sucesso) ou 1 (falha).

Comentários

sp_dropdistributor é usado em todos os tipos de replicação.

Se existirem outros objetos do Publisher ou de distribuição no servidor, sp_dropdistributor falhará a menos que @no_checks esteja definido como 1.

Esse procedimento armazenado deve ser executado depois de descartar o banco de dados de distribuição executando sp_dropdistributiondbo .

Exemplos

-- 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".

-- Disable publishing and distribution.
DECLARE @distributionDB AS sysname;
DECLARE @publisher AS sysname;
DECLARE @publicationDB as sysname;
SET @distributionDB = N'distribution';
SET @publisher = $(DistPubServer);
SET @publicationDB = N'AdventureWorks2022';

-- Disable the publication database.
USE [AdventureWorks2022]
EXEC sp_removedbreplication @publicationDB;

-- Remove the registration of the local Publisher at the Distributor.
USE master
EXEC sp_dropdistpublisher @publisher;

-- Delete the distribution database.
EXEC sp_dropdistributiondb @distributionDB;

-- Remove the local server as a Distributor.
EXEC sp_dropdistributor;
GO

Permissões

Somente membros da função de servidor fixa sysadmin podem executar sp_dropdistributor.