Поделиться через


sp_dropsubscription (Transact-SQL)

Удаляет подписки на некоторую статью, публикацию или набор подписок на издателе. Эта хранимая процедура выполняется на издателе в базе данных публикации.

Значок ссылки на разделСинтаксические обозначения в Transact-SQL

Синтаксис

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

Аргументы

  • [ @publication = ] 'publication'
    Имя связанной публикации. Аргумент publication имеет тип sysname и значение по умолчанию NULL. Если имеет значение all, то все подписки для всех публикаций для указанного подписчика будут отменены. publication — необходимый аргумент.
  • [ @article = ] 'article'
    Имя статьи. Аргумент article имеет тип sysname и значение по умолчанию NULL. Если имеет значение all, подписки на все статьи для каждой указанной публикации и подписчика будут удалены. Используйте значение all для публикаций, которые позволяют немедленное обновление. article — необходимый аргумент.
  • [ @subscriber = ] 'subscriber'
    Имя подписчика, для которого будут удалены все его подписки. Аргумент subscriber имеет тип sysname и не имеет значения по умолчанию. Если имеет значение all, то все подписки для всех подписчиков удаляются.
  • [ @destination_db = ] 'destination_db'
    Имя целевой базы данных. Аргумент destination_db имеет тип sysname и значение по умолчанию NULL. Если имеет значение NULL, то все подписки от этого подписчика удаляются.
  • [ @ignore_distributor = ] ignore_distributor
    Только для внутреннего использования.
  • [ @reserved = ] 'reserved'
    Только для внутреннего использования.

Значения кодов возврата

0 (успешное завершение) или 1 (неуспешное завершение)

Замечания

Хранимая процедура sp_dropsubscription используется при репликации моментальных снимков и репликации транзакций.

Если удаляется подписка на статью в публикации с немедленной синхронизацией, то нельзя добавить ее обратно до тех пор, пока не будут удалены подписки на все статьи в публикации и, затем, не добавлены все одновременно обратно.

Разрешения

Только члены фиксированной серверной роли sysadmin и фиксированной роли базы данных db_owner, или пользователи, создавшие подписку, могут выполнять хранимую процедуру sp_dropsubscription.

Пример

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

См. также

Справочник

sp_addsubscription (Transact-SQL)
sp_changesubstatus (Transact-SQL)
sp_helpsubscription (Transact-SQL)

Другие ресурсы

How to: Delete a Push Subscription (Replication Transact-SQL Programming)

Справка и поддержка

Получение помощи по SQL Server 2005