sp_reinitpullsubscription (Transact-SQL)

將交易式提取或匿名訂閱標示為在下次執行散發代理程式時重新初始化。這個預存程序執行於提取訂閱資料庫的訂閱者端。

主題連結圖示Transact-SQL 語法慣例

語法

sp_reinitpullsubscription [ @publisher = ] 'publisher'
        , [ @publisher_db = ] 'publisher_db'
        , [ @publication = ] 'publication'

引數

  • [@publisher=] 'publisher'
    這是發行者的名稱。publishersysname,沒有預設值。

  • [@publisher_db=] 'publisher_db'
    這是發行者資料庫的名稱。publisher_dbsysname,沒有預設值。

  • [@publication=] 'publication'
    這是發行集的名稱。publicationsysname,預設值是 all,將所有訂閱標示為重新初始化。

傳回碼值

0 (成功) 或 1 (失敗)

備註

sp_reinitpullsubscription 用於交易式複寫中。

不支援點對點交易式複寫使用 sp_reinitpullsubscription

在下次執行散發代理程式期間,您可以從訂閱者呼叫 sp_reinitpullsubscription 來重新初始化訂閱。

您無法從訂閱者重新初始化對於利用 @immediate_sync 的 false 值來建立之發行集的訂閱。

您可以在訂閱者端執行 sp_reinitpullsubscription,或在發行者端執行 sp_reinitsubscription,來重新初始化提取訂閱。

範例

-- 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".

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

USE [AdventureWorks2008R2Replica]

-- Execute at the Subscriber to reinitialize the pull subscription. 
EXEC sp_reinitpullsubscription 
    @publisher = $(PubServer),
    @publisher_db = @publicationDB,
    @publication = @publication;
GO

-- Start the Distribution Agent.

權限

只有系統管理員 (sysadmin) 固定伺服器角色或 db_owner 固定資料庫角色的成員,才能夠執行 sp_reinitpullsubscription