sp_droparticle (Transact-SQL)

适用于:SQL ServerAzure SQL 托管实例

从快照发布或事务发布中删除一个项目。 如果存在一个或多个订阅,则无法删除项目。 此存储过程在发布服务器上对发布数据库执行。

Transact-SQL 语法约定

语法

sp_droparticle
    [ @publication = ] N'publication'
    , [ @article = ] N'article'
    [ , [ @ignore_distributor = ] ignore_distributor ]
    [ , [ @force_invalidate_snapshot = ] force_invalidate_snapshot ]
    [ , [ @publisher = ] N'publisher' ]
    [ , [ @from_drop_publication = ] from_drop_publication ]
[ ; ]

参数

[ @publication = ] N'publication'

包含要删除的项目的发布的名称。 @publicationsysname,无默认值。

[ @article = ] N'article'

要删除的项目的名称。 @articlesysname,无默认值。

[ @ignore_distributor = ] ignore_distributor

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

[ @force_invalidate_snapshot = ] force_invalidate_快照

确认此存储过程执行的操作可能会使现有快照失效。 @force_invalidate_快照为,默认值为 0.

  • 0指定对项目所做的更改不会导致快照无效。 如果该存储过程检测到更改确实需要新的快照,则会发生错误,并且不进行任何更改。

  • 1指定对项目所做的更改可能会导致快照无效,如果存在需要新快照的现有订阅,则授予现有快照标记为已过时和生成的新快照的权限。

[ @publisher = ] N'publisher'

指定非 SQL Server 发布服务器。 @publisher为 sysname,默认值为 NULL.

更改 SQL Server 发布服务器上的项目属性时,不应使用此参数。

[ @from_drop_publication = ] from_drop_publication

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

返回代码值

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

注解

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

对于水平筛选的项目, sp_droparticle 检查 type sysarticles(Transact-SQL)表中文章的列,以确定是否还应删除视图或筛选器。 如果自动生成了视图或筛选器,则会随文章一起删除。 如果手动创建,则不会将其删除。

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

示例

DECLARE @publication AS sysname;
DECLARE @article AS sysname;
SET @publication = N'AdvWorksProductTran'; 
SET @article = N'Product'; 

-- Drop the transactional article.
USE [AdventureWorks2022]
EXEC sp_droparticle 
  @publication = @publication, 
  @article = @article,
  @force_invalidate_snapshot = 1;
GO

权限

只有 sysadmin 固定服务器角色的成员db_owner固定数据库角色的成员才能执行sp_droparticle