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


sp_dropsubscription (Transact-SQL)

Область применения: SQL Server Управляемый экземпляр SQL Azure

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

Соглашения о синтаксисе Transact-SQL

Синтаксис

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

Аргументы

[ @publication = ] N'publication'

Имя связанной публикации. @publication — sysname с значением по умолчаниюNULL. Если allвсе подписки для всех публикаций для указанного подписчика отменены. публикация является обязательным параметром.

[ @article = ] N'article'

Имя статьи. @article — sysname с значением по умолчаниюNULL. Если allподписки на все статьи для каждой указанной публикации и подписчика удаляются. Используется all для публикаций, которые позволяют немедленно обновляться.

[ @subscriber = ] N'подписчик'

Имя подписчика, удаляющего свои подписки. @subscriber — sysname без значения по умолчанию. Если allвсе подписки для всех подписчиков удаляются.

[ @destination_db = ] N'destination_db'

Имя целевой базы данных. @destination_db имеет имя sysname с значением по умолчаниюNULL. Если NULLвсе подписки из этого подписчика удаляются.

[ @ignore_distributor = ] ignore_distributor

Указано только в ознакомительных целях. Не поддерживается. Совместимость с будущими версиями не гарантируется.

[ @reserved = ] N'reserved'

Указано только в ознакомительных целях. Не поддерживается. Совместимость с будущими версиями не гарантируется.

[ @publisher = ] N'publisher'

Указано только в ознакомительных целях. Не поддерживается. Совместимость с будущими версиями не гарантируется.

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

0 (успешно) или 1 (сбой).

Замечания

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 [AdventureWorks2022]
EXEC sp_dropsubscription 
  @publication = @publication, 
  @article = N'all',
  @subscriber = @subscriber;
GO

Разрешения

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