sp_droppublication (Transact-SQL)

适用于:SQL ServerAzure SQL 托管实例

删除发布及其关联的快照代理。 删除发布之前必须删除全部的订阅。 发布中的项目将自动删除。 此存储过程在发布服务器上对发布数据库执行。

Transact-SQL 语法约定

语法

sp_droppublication
    [ @publication = ] N'publication'
    [ , [ @ignore_distributor = ] ignore_distributor ]
    [ , [ @publisher = ] N'publisher' ]
    [ , [ @from_backup = ] from_backup ]
[ ; ]

参数

[ @publication = ] N'publication'

要删除的发布的名称。 @publicationsysname,无默认值。 如果 all 已指定,则从发布数据库中删除所有发布,但具有订阅的发布除外。

[ @ignore_distributor = ] ignore_distributor

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

[ @publisher = ] N'publisher'

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

[ @from_backup = ] from_backup

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

返回代码值

0(成功)或 1(失败)。

注解

sp_droppublication用于快照 副本 (replica)和事务副本 (replica)。

sp_droppublication 以递归方式删除与发布关联的所有项目,然后删除发布本身。 如果发布是一个或多个订阅,则无法将其删除。 有关如何删除订阅的信息,请参阅 “删除推送订阅 ”和 “删除请求订阅”。

执行 sp_droppublication 删除发布不会从发布数据库中删除已发布对象或订阅数据库中的相应对象。 如果需要,可以使用 DROP <object> 手动删除这些对象。

权限

只有 sysadmin 固定服务器角色的成员才能执行sp_droppublication

示例

DECLARE @publicationDB AS sysname;
DECLARE @publication AS sysname;
SET @publicationDB = N'AdventureWorks'; 
SET @publication = N'AdvWorksProductTran'; 

-- Remove a transactional publication.
USE [AdventureWorks2022]
EXEC sp_droppublication @publication = @publication;

-- Remove replication objects from the database.
USE [master]
EXEC sp_replicationdboption 
  @dbname = @publicationDB, 
  @optname = N'publish', 
  @value = N'false';
GO