合併式複寫的衝突解決
適用於:SQL Server
合併式複寫中的衝突根據為每個發行項指定的解決器進行解決。 依預設,衝突的解決不需要使用者的介入。 但是可以在 Microsoft 複寫衝突檢視器中檢視衝突及變更解決的結果。
複寫衝突檢視器可以在衝突保留期限指定的時間內使用衝突資料 (預設為 14 天)。 若要設定衝突保留期限,可以:
針對 sp_addmergepublication (Transact-SQL) 的
@conflict_retention
參數指定保留值。針對 sp_changemergepublication (Transact-SQL) 的
@property
參數指定 conflict_retention 的值,並為@value
參數指定保留值。
依預設,會儲存衝突資訊:
- 如果發行集相容性層級為 90RTM 或更高,則是在「發行者」與「訂閱者」端。
- 如果發行集相容性層級低於 80RTM,則是在發行者端。
- 如果訂閱者正在執行 SQL Server Compact,則在發行者端。 衝突資料無法儲存在 SQL Server Compact 訂閱者上。
衝突資訊的儲存由 conflict_logging 發行集屬性控制。 如需詳細資訊,請參閱 sp_addmergepublication (Transact-SQL) 和 sp_changemergepublication (Transact-SQL)。
也可以使用 Microsoft 互動解析程式,在同步處理期間以互動的方式解決衝突。 互動解析程式會透過 Microsoft Windows Synchronization Manager 可供使用。 如需詳細資訊,請參閱使用 Windows 同步處理管理員同步處理訂閱 (Windows 同步處理管理員)。
解決衝突
連線至 SQL Server Management Studio 中的發行者 (或是適用的訂閱者),然後展開伺服器節點。
展開 [複寫] 資料夾,然後展開 [本機發行集] 資料夾。
以滑鼠右鍵按一下您要檢視衝突的發行集,然後按一下 [檢視衝突] 。
注意
如果將 conflict_logging 屬性的值指定為 'subscriber' ,就無法使用 [檢視衝突] 功能表選項。 若要檢視衝突,請從命令提示字元啟動 ConflictViewer.exe。 依預設,ConflictViewer.exe 位於下列目錄:Microsoft SQL Server\100\Tools\Binn\VSShell\Common7\IDE。 如需有效的啟動參數清單,請執行 ConflictViewer.exe -?。
在 [選取衝突資料表] 對話方塊中,選取要檢視衝突的資料庫、發行集和資料表。
在複寫衝突檢視器中,您可以:
使用上方格右側按鈕篩選資料列。
在上方格內選取資料列,以便於下方格的該資料列顯示資訊。
在上方方格中選取一個或多個資料列,然後按一下 [移除],這相當於按一下 [提交成功者] 按鈕 (不會對資料進行任何變更)。
按一下屬性按鈕 ([...]) 以檢視更多有關於衝突的資料行資訊。
在提交資料之前,編輯 [衝突成功者] 或 [衝突失敗者] 資料行中的資料 (灰色資料行表示資料為唯讀)。
按一下 [提交成功者] 以接受指定為衝突成功者的資料列。
按一下 [提交失敗者] ,以覆寫解決並將指定為衝突失敗者的值傳播到拓撲中的所有節點。
選取 [記錄此衝突的詳細資料] 即可將衝突資料記錄到檔案中。 若要指定檔案的位置,請指向 [檢視] 功能表,然後按一下 [選項] 。 輸入值,或按一下瀏覽按鈕 ( [...] ),然後導覽至適當的檔案。 按一下 [確定] 即可結束 [選項] 對話方塊。
關閉複寫衝突檢視器。
檢視衝突資訊
在合併式複寫中解決衝突時,遺失之資料列的資料會寫入衝突資料表。 可以使用複寫預存程序來以程式設計的方式檢視此衝突資料。 如需詳細資訊,請參閱 進階合併式複寫衝突偵測與解決。
在發行集資料庫的發行者上,執行 sp_helpmergepublication。 請注意結果集中下列資料行的值:
centralized_conflicts - 1 表示在發行者上儲存衝突資料列,0 則表示不會在發行者上儲存衝突資料列。
decentralized_conflicts - 1 表示在訂閱者上儲存衝突資料列,0 則表示不會在訂閱者上儲存衝突資料列。
注意
合併式發行集之衝突記錄行為是使用 sp_addmergepublication 的
@conflict_logging
參數來設定。 已淘汰使用@centralized_conflicts
參數。
下表描述這些資料行的值 (根據針對
@conflict_logging
所指定的值)。@conflict_logging value centralized_conflicts decentralized_conflicts publisher 1 0 訂閱者 0 1 兩者 1 1 在發行集資料庫的發行者上或是在訂閱資料庫的訂閱者上,執行 sp_helpmergearticleconflicts。 針對
@publication
指定值,只傳回屬於特定發行集的發行項衝突資訊。 這樣會傳回有衝突之發行項的衝突資料表資訊。 請記下感興趣之任何發行項的 conflict_table 值。 如果發行項的 conflict_table 值為 NULL,只要刪除此發行項中已發生的衝突。(選擇性) 檢閱感興趣之發行項的衝突資料列。 根據步驟 1 中 centralized_conflicts 和 decentralized_conflicts 的值而定,執行下列其中一項:
在發行集資料庫的發行者上,執行 sp_helpmergeconflictrows。 針對
@conflict_table
指定發行項的衝突資料表 (來自步驟 1)。 (選擇性) 指定@publication
的值,將傳回的衝突資訊限制為特定發行集。 這樣會傳回遺失之資料列的資料列資料和其他資訊。在訂閱資料庫的訂閱者上,執行 sp_helpmergeconflictrows。 針對
@conflict_table
指定發行項的衝突資料表 (來自步驟 1)。 這樣會傳回遺失之資料列的資料列資料和其他資訊。
發生刪除失敗的衝突
在發行集資料庫的發行者上,執行 sp_helpmergepublication。 請注意結果集中下列資料行的值:
centralized_conflicts - 1 表示在發行者上儲存衝突資料列,0 則表示不會在發行者上儲存衝突資料列。
decentralized_conflicts - 1 表示在訂閱者上儲存衝突資料列,0 則表示不會在訂閱者上儲存衝突資料列。
注意
合併式發行集之衝突記錄行為是使用 sp_addmergepublication 的
@conflict_logging
參數來設定。 已淘汰使用@centralized_conflicts
參數。
在發行集資料庫的發行者上或是在訂閱資料庫的訂閱者上,執行 sp_helpmergearticleconflicts。 針對
@publication
指定值,只傳回屬於特定發行集的發行項衝突資料表資訊。 這樣會傳回有衝突之發行項的衝突資料表資訊。 請記下感興趣之任何發行項的 source_object 值。 如果發行項的 conflict_table 值為 NULL,只要刪除此發行項中已發生的衝突。(選擇性) 檢閱刪除衝突的衝突資訊。 根據步驟 1 中 centralized_conflicts 和 decentralized_conflicts 的值而定,執行下列其中一項:
在發行集資料庫的發行者上,執行 sp_helpmergedeleteconflictrows。 針對
@source_object
指定衝突發生所在的來源資料表名稱 (來自步驟 1)。 (選擇性) 指定@publication
的值,將傳回的衝突資訊限制為特定發行集。 這樣會傳回儲存在發行者上的刪除衝突資訊。在訂閱資料庫的訂閱者上,執行 sp_helpmergedeleteconflictrows。 針對
@source_object
指定衝突發生所在的來源資料表名稱 (來自步驟 1)。 (選擇性) 指定@publication
的值,將傳回的衝突資訊限制為特定發行集。 這樣會傳回儲存在訂閱者上的刪除衝突資訊。