Share via


如何:定義和修改靜態資料列篩選 (SQL Server Management Studio)

在「新增發行集精靈」的 [篩選資料表的資料列] 頁面上,或在 [發行集屬性 - <Publication>] 對話方塊的 [篩選資料列] 頁面上,定義、修改和刪除靜態資料列篩選。如需有關使用此精靈及存取此對話方塊的詳細資訊,請參閱<如何:建立發行集並定義發行項 (SQL Server Management Studio)>與<如何:檢視和修改發行集與發行項屬性 (SQL Server Management Studio)>。如果為點對點交易式複寫啟用發行集,則無法篩選資料表。

[!附註]

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

若要定義靜態資料列篩選

  1. 在「新增發行集精靈」的 [篩選資料表的資料列] 頁面上,或在 [發行集屬性 - <Publication>] 對話方塊的 [篩選資料列] 頁面上,您所採取的動作要視發行集類型而定:

    • 對於快照式或交易式發行集,請按一下 [加入]

    • 對於合併式發行集,請按一下 [加入],然後按一下 [加入篩選]

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

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

    [!附註]

    WHERE 子句應使用兩部份命名;不支援三部份及四部份命名。如果發行集來自「Oracle 發行者」,則 WHERE 子句必須與 Oracle 語法相容。

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

      SELECT <published_columns> FROM [schema].[tablename] WHERE
      
    • 預設的文字無法變更;使用標準 SQL 語法,在 WHERE 關鍵字後面輸入篩選子句。完整的篩選子句應類似於:

      SELECT <published_columns> FROM [HumanResources].[Employee] WHERE [LoginID] = 'adventure-works\ranjit0'
      
    • 靜態資料列篩選可以包含使用者定義函數。含有使用者定義函數的靜態資料列篩選之完整的篩選子句應類似於:

      SELECT <published_columns> FROM [Sales].[SalesOrderHeader] WHERE MyFunction([Freight]) > 100
      
  4. 按一下 [確定]。

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

若要修改靜態資料列篩選

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

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

  3. 按一下 [確定]。

若要刪除靜態資料列篩選

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