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


sp_droppullsubscription (Transact-SQL)

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

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

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

Синтаксис

sp_droppullsubscription
    [ @publisher = ] N'publisher'
    [ , [ @publisher_db = ] N'publisher_db' ]
    , [ @publication = ] N'publication'
    [ , [ @reserved = ] reserved ]
    [ , [ @from_backup = ] from_backup ]
[ ; ]

Аргументы

[ @publisher = ] N'publisher'

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

[ @publisher_db = ] N'publisher_db'

Имя базы данных издателя. @publisher_db имеет имя sysname с значением по умолчаниюNULL. all означает все базы данных издателя.

[ @publication = ] N'publication'

Название публикации. @publication — sysname без значения по умолчанию. Если allподписка удаляется на все публикации.

[ @reserved = ] зарезервировано

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

[ @from_backup = ] from_backup

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

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

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

Замечания

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

sp_droppullsubscription Удаляет соответствующую строку в таблице MSreplication_subscriptions и соответствующий агент распространителя на подписчике. Если строки отсутствуют в MSreplication_subscriptions, она удаляет таблицу.

Примеры

-- 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 is the batch executed at the Subscriber to drop 
-- a pull subscription to a transactional publication.
DECLARE @publication AS sysname;
DECLARE @publisher AS sysname;
DECLARE @publicationDB     AS sysname;
SET @publication = N'AdvWorksProductTran';
SET @publisher = $(PubServer);
SET @publicationDB = N'AdventureWorks2022';

USE [AdventureWorks2022Replica]
EXEC sp_droppullsubscription 
  @publisher = @publisher, 
  @publisher_db = @publicationDB, 
  @publication = @publication;
GO

Разрешения

Могут выполняться sp_droppullsubscriptionтолько члены предопределенных ролей сервера sysadmin или пользователя, создавшего подписку на вытягивание. Роль фиксированной базы данных db_owner может выполняться sp_droppullsubscription только в том случае, если пользователь, создавший подписку на вытягивание, принадлежит этой роли.