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


sp_dropmergepullsubscription (Transact-SQL)

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

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

Синтаксис

sp_dropmergepullsubscription [ @publication= ] 'publication' 
        , [ @publisher= ] 'publisher' 
        , [ @publisher_db= ] 'publisher_db' 
    [ , [ @reserved= ] 'reserved' ]

Аргументы

  • [ @publication=] 'publication'
    Имя публикации. Аргумент publication имеет тип sysname и значение по умолчанию NULL. Этот аргумент обязателен. Укажите в качестве значения all, чтобы удалить подписки на все публикации.

  • [ @publisher=] 'publisher'
    Имя издателя. Аргумент publisher имеет тип sysname и значение по умолчанию NULL. Этот аргумент обязателен.

  • [ @publisher_db=] 'publisher_db'
    Имя базы данных издателя. Аргумент publisher_db имеет тип sysname и значение по умолчанию NULL. Этот аргумент обязателен.

  • [ @reserved=] 'reserved'
    Зарезервировано для использования в будущем. Аргумент reserved имеет тип bit и значение по умолчанию 0.

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

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

Замечания

Процедура sp_dropmergepullsubscription используется в репликации слиянием.

Процедура sp_dropmergepullsubscription удаляет агент слияния для этой подписки слиянием по запросу, хотя агент слияния не создается в процедуре sp_addmergepullsubscription.

Пример

-- 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 Subscriber to remove 
-- a merge pull subscription.
DECLARE @publication AS sysname;
DECLARE @publisher AS sysname;
DECLARE @publication_db AS sysname;
SET @publication = N'AdvWorksSalesOrdersMerge';
SET @publisher = $(PubServer);
SET @publication_db = N'AdventureWorks';

USE [AdventureWorksReplica]
EXEC sp_dropmergepullsubscription 
  @publisher = @publisher, 
  @publisher_db = @publication_db, 
  @publication = @publication;
GO

Разрешения

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