如何:定義和修改合併發行項的參數化資料列篩選器 (SQL Server Management Studio)

在「新增發行集精靈」的 [篩選資料表資料列] 頁面,或在 [發行集屬性 - <Publication>] 對話方塊的 [篩選資料列] 頁面中,定義、修改和刪除參數化資料列篩選器。如需有關使用此精靈及存取此對話方塊的詳細資訊,請參閱<如何:建立發行集並定義發行項 (SQL Server Management Studio)>與<如何:檢視和修改發行集與發行項屬性 (SQL Server Management Studio)>。

[!附註]

如果您在初始化發行集訂閱後,在 [發行集屬性 - <Publication>] 對話方塊中新增、修改或刪除參數化資料列篩選器,則必須在進行變更後產生新的快照集並重新初始化所有訂閱。如需屬性變更需求的資訊,請參閱<變更發行集與發行項屬性>。

若要定義參數化資料列篩選器

  1. 在「新增發行集精靈」的 [篩選資料表的資料列] 頁面,或在 [發行集屬性 - <Publication>][篩選資料列] 頁面中,按一下 [加入],然後按一下 [加入篩選]

  2. [加入篩選] 對話方塊中,從下拉式清單方塊中選取要篩選的資料表。

  3. [篩選陳述式] 文字方塊中建立篩選陳述式。您可直接在文字區域輸入,也可以從 [資料行] 清單方塊中拖曳資料行。

    • [篩選陳述式] 文字區域包括預設文字,其格式為:

      SELECT <published_columns> FROM [tableowner].[tablename] WHERE
      
    • 預設的文字無法變更;使用標準 SQL 語法,在 WHERE 關鍵字後面輸入篩選子句。參數化篩選包括對系統函數 HOST_NAME() 與/或 SUSER_SNAME() 的呼叫,或參考上述一或兩個函數的使用者定義函數。下列為參數化資料列篩選器的完整篩選子句範例:

      SELECT <published_columns> FROM [HumanResources].[Employee] WHERE LoginID = SUSER_SNAME()
      

      WHERE 子句應使用兩部份命名;不支援三部份及四部份命名。

      重要事項重要事項

      基於效能原因,建議您不要在參數化資料列篩選器子句中的資料行名稱套用函數,例如 LEFT([MyColumn]) = SUSER_SNAME()。如果在篩選子句中使用 HOST_NAME,並且覆寫了 HOST_NAME 值,則可能需要使用 CONVERT 轉換資料類型。如需此案例之最佳作法的詳細資訊,請參閱主題<參數化資料列篩選器>中的「複寫 HOST_NAME() 值」一節。

  4. 選取符合資料在訂閱者之間共用資料方式的選項:

    • 這個資料表中的一個資料列會提供給多個訂閱

    • 這個資料表中的一個資料列只會提供給一個訂閱

    若您選取 [這個資料表中的一個資料列只會提供給一個訂閱],合併式複寫可藉由儲存和處理較少中繼資料來將效能最佳化。不過您必須確定資料分割方式不會將資料列複寫至多個訂閱者。如需進一步資訊,請參閱主題<參數化資料列篩選器>中的「設定資料分割選項」。

  5. 按一下 [確定]。

  6. 如果您是在 [發行集屬性 - <Publication>] 對話方塊中,請按一下 [確定] 以儲存並關閉對話方塊。

若要修改參數化資料列篩選器

  1. 在新增發行集精靈的 [篩選資料表的資料列] 頁面,或者 [發行集屬性 - <Publication>][篩選資料列] 頁面上,選取 [已篩選的資料表] 窗格中的篩選,然後按一下 [編輯]

  2. [編輯篩選] 對話方塊中,修改篩選。

  3. 按一下 [確定]。

若要刪除參數化資料列篩選器

  • 在新增發行集精靈的 [篩選資料表的資料列] 頁面,或者 [發行集屬性 - <Publication>][篩選資料列] 頁面上,選取 [已篩選的資料表] 窗格中的篩選,然後按一下 [刪除]