sp_droppullsubscription (Transact-SQL)

适用于:SQL Server (所有受支持的版本) Azure SQL 托管实例

在订阅服务器的当前数据库中删除订阅。 此存储过程在订阅服务器上对请求订阅数据库执行。

主题链接图标Transact-SQL 语法约定

语法

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

参数

[ @publisher = ] 'publisher' 远程服务器名称。 publishersysname,无默认值。 如果 全部,则会在所有发布服务器上删除订阅。

[ @publisher_db = ] 'publisher_db' 发布服务器数据库的名称。 publisher_dbsysname,没有默认值。 全部 表示所有发布服务器数据库。

[ @publication = ] 'publication' 发布名称。 发布sysname,无默认值。 如果 全部,订阅将删除到所有发布。

[ @reserved = ] reserved

标识为仅供参考。 不支持。 不保证以后的兼容性。

返回代码值

0 (成功) 或 1 (失败)

备注

sp_droppullsubscription 用于快照复制和事务复制。

sp_droppullsubscription 删除 MSreplication_subscriptions (Transact-SQL) 表中的相应行,并在订阅服务器上删除相应的分发服务器代理。 如果 MSreplication_subscriptions (transact-SQL) 中没有留下任何行,则会删除该表。

示例

-- 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'AdventureWorks2012';

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

权限

只有 sysadmin 固定服务器角色的成员或创建请求订阅的用户才能执行 sp_droppullsubscription仅当创建请求订阅的用户属于此角色时,db_owner固定数据库角色才能够执行sp_droppullsubscription

另请参阅

删除请求订阅
sp_addpullsubscription (Transact-SQL)
sp_change_subscription_properties (Transact-SQL)
sp_helppullsubscription (Transact-SQL)
sp_dropsubscription (Transact-SQL)