sp_droppublication (Transact-SQL)
Elimina una pubblicazione e l'agente snapshot associato. Prima di eliminare una pubblicazione, è necessario eliminare tutte le sottoscrizioni. Gli articoli della pubblicazione vengono eliminati automaticamente. Questa stored procedure viene eseguita nel database di pubblicazione del server di pubblicazione.
Sintassi
sp_droppublication [ @publication= ] 'publication'
[ , [ @ignore_distributor = ] ignore_distributor ]
Argomenti
[ @publication= ] 'publication'
Nome della pubblicazione da eliminare. publication è di tipo sysname e non prevede alcun valore predefinito. Se viene specificato all, dal database di pubblicazione vengono eliminate tutte le pubblicazioni, ad eccezione di quelle che includono sottoscrizioni.[ @ignore_distributor = ] ignore_distributor
Identificato solo a scopo informativo. Non supportato. Non è garantita la compatibilità con le versioni future.
Valori restituiti
0 (esito positivo) o 1 (esito negativo)
Osservazioni
sp_droppublication viene utilizzata per la replica snapshot e transazionale.
sp_droppublication elimina in modo ricorsivo tutti gli articoli associati a una pubblicazione e quindi elimina la pubblicazione stessa. Non è possibile rimuovere una pubblicazione per cui esistono una o più sottoscrizioni. Per informazioni sulla rimozione di sottoscrizioni, vedere Procedura: Eliminazione di una sottoscrizione push (programmazione Transact-SQL della replica) e Procedura: Eliminazione di una sottoscrizione pull (programmazione Transact-SQL della replica).
L'esecuzione di sp_droppublication per l'eliminazione di una pubblicazione non comporta la rimozione degli oggetti pubblicati dal database di pubblicazione né degli oggetti corrispondenti dal database di sottoscrizione. Utilizzare DROP <object> per rimuovere questi oggetti manualmente, se necessario.
Esempi
DECLARE @publicationDB AS sysname;
DECLARE @publication AS sysname;
SET @publicationDB = N'AdventureWorks2008R2';
SET @publication = N'AdvWorksProductTran';
-- Remove a transactional publication.
USE [AdventureWorks2008R2]
EXEC sp_droppublication @publication = @publication;
-- Remove replication objects from the database.
USE [master]
EXEC sp_replicationdboption
@dbname = @publicationDB,
@optname = N'publish',
@value = N'false';
GO
Autorizzazioni
Solo i membri del ruolo predefinito del server sysadmin o del ruolo predefinito del database db_owner possono eseguire sp_droppublication.