共用方式為


加入或編輯聯結

[加入聯結][編輯聯結] 對話方塊可讓您為合併發行集加入和編輯聯結篩選。

[!附註]

編輯現有發行集內的篩選需要該發行集的新快照集。如果發行集有訂閱,就必須重新初始化訂閱。如需有關屬性變更的詳細資訊,請參閱<變更發行集與發行項屬性>。

聯結篩選可讓您根據發行集內相關資料表的篩選方式來篩選資料表。通常,父資料表會使用參數化資料列篩選器進行篩選,然後一或多個聯結篩選會以您在資料表之間定義聯結的相同方式進行定義。聯結篩選會擴充資料列篩選,以便只有當資料與聯結篩選子句相符時,才複寫相關資料表中的資料。

聯結篩選通常會遵循為套用到之資料表所定義的主索引鍵/外部索引鍵關聯性,但並非嚴格受限於主索引鍵/外部索引鍵關聯性。聯結篩選可以根據任何比較兩個發行項資料表中之相關資料的邏輯。

重要事項重要事項

聯結篩選可以包含無限數量的資料表,但如果篩選的資料表數量過多,會影響合併處理過程中的效能。如果您要產生五個或以上之資料表的聯結篩選,請考慮其他方案:請勿篩選小型資料表、無法變更的資料表,或主要是查閱資料表的資料表。聯結篩選只能用於必須在訂閱者中分割的資料表之間。

選項

這個對話方塊包括三個步驟的處理程序,以在兩個資料表之間建立一個聯結篩選。若要建立一個以上的聯結篩選,就必須執行此對話方塊一次以上。

  1. 確認已篩選的資料表並選取聯結的資料表

    • 如果您正在加入新聯結,請確認 [已篩選的資料表] 文字方塊中的資料表是正確的 (如果不正確,請按一下 [取消],在 [篩選資料表的資料列] 頁面上選取正確的資料表,然後按一下 [加入聯結] 即可回到此對話方塊)。接著,從 [聯結的資料表] 下拉式清單方塊中選取資料表。

    • 如果是編輯現有的聯結,則資料表名稱已經指定且無法變更。若要變更涉及聯結的資料表,必須在 [篩選資料表的資料列] 頁面上刪除現有的聯結篩選,然後在不同的資料表之間建立新聯結。

  2. 建立聯結陳述式

    • 如果是加入新聯結,請選取 [使用產生器建立陳述式][手動寫入聯結陳述式]。如果您一開始是以手動寫入聯結,就無法使用產生器。

      如果選取使用產生器,請使用方格中的資料行 ([結合][已篩選的資料表資料行][運算子][聯結的資料表資料行]) 來建立聯結陳述式。方格中的每個資料行均包含一個下拉式清單方塊,可讓您選取兩個資料行和一個運算子 ([=][<>][<=][<][>=][>][類似])。結果會在 [預覽] 文字區域中顯示。如果聯結涉及一對以上的資料行,請從 [結合] 資料行中選取一個結合 ([AND][OR]),然後輸入兩個或更多的資料行及另一個運算子。

      如果選取手動寫入陳述式,請在 [聯結陳述式] 文字區域寫入聯結陳述式。使用 [已篩選的資料表資料行] 清單方塊和 [聯結的資料表資料行] 清單方塊,將資料行拖放到 [聯結陳述式] 文字區域。

    • 如果是編輯現有的聯結,您必須以手動進行編輯。

  3. 指定聯結選項

    • 如果在已篩選的資料表中聯結的資料行是唯一的,請選取 [唯一索引鍵]。如果資料行是唯一的,合併處理可以使用特殊效能最佳化。

      警告注意事項注意

      選取此選項表示聯結篩選中的子資料表與父資料表之間的關聯性是一對一或一對多。如果在父資料表中的聯結資料行有保證唯一性的條件約束,請僅選取此選項。如果選項設定不正確,則資料可能發生非聚合的情況。

    • Microsoft 僅限 SQL Server 2005 和更新版本。依預設,合併式複寫在同步處理過程中會按逐個資料列的方式處理變更。若要將相關的變更作為一個單位來處理,請選取 [邏輯記錄]。只有當發行項與發行集之使用邏輯記錄的需求均符合時,才可以使用此選項。如需詳細資訊,請參閱<使用邏輯記錄分組相關資料列的變更>中的「使用邏輯記錄的考量」一節。

您加入或編輯篩選之後,請按一下 [確定] 以儲存變更並關閉對話方塊。您指定的篩選會被剖析,並會針對 SELECT 子句中的資料表執行。如果篩選陳述式包含語法錯誤或其他問題,則系統會通知您,然後您可以編輯該篩選陳述式。