sp_articleview (Transact-SQL)

适用于: SQL Server Azure SQL 托管实例

在垂直或水平筛选表时创建用于定义已发布项目的视图。 该视图用作目标表的架构和数据的筛选源。 只有未订阅的项目才能由此存储过程修改。 此存储过程在发布服务器上对发布数据库执行。

Transact-SQL 语法约定

语法

sp_articleview
    [ @publication = ] N'publication'
    , [ @article = ] N'article'
    [ , [ @view_name = ] N'view_name' ]
    [ , [ @filter_clause = ] N'filter_clause' ]
    [ , [ @change_active = ] change_active ]
    [ , [ @force_invalidate_snapshot = ] force_invalidate_snapshot ]
    [ , [ @force_reinit_subscription = ] force_reinit_subscription ]
    [ , [ @publisher = ] N'publisher' ]
    [ , [ @refreshsynctranprocs = ] refreshsynctranprocs ]
    [ , [ @internal = ] internal ]
[ ; ]

参数

[ @publication = ] N'publication'

包含项目的发布的名称。 @publicationsysname,无默认值。

[ @article = ] N'article'

项目的名称。 @articlesysname,无默认值。

[ @view_name = ] N'view_name'

定义已发布项目的视图的名称。 @view_namenvarchar(386),默认值为 NULL.

[ @filter_clause = ] N'filter_clause'

定义水平筛选器的限制 (WHERE) 子句。 输入限制子句时,省略 WHERE 关键字。 @filter_clausenvarchar(max),默认值为 NULL.

[ @change_active = ] change_active

允许修改具有订阅的发布中的列。 @change_active为 int,默认值为 0.

  • 如果 0更改列,则不会更改列。
  • 如果 1,可以在具有订阅的活动项目上创建或重新创建视图。

[ @force_invalidate_snapshot = ] force_invalidate_snapshot

确认此存储过程执行的操作可能会使现有快照失效。 @force_invalidate_snapshot为,默认值为 0.

  • 0 指定对项目所做的更改不会导致快照无效。 如果该存储过程检测到更改确实需要新的快照,则会发生错误,并且不进行任何更改。
  • 1 指定对项目所做的更改可能会导致快照无效,如果存在需要新快照的现有订阅,则授予现有快照标记为已过时和生成的新快照的权限。

[ @force_reinit_subscription = ] force_reinit_subscription

确认此存储过程所执行的操作是否需要重新初始化现有订阅。 @force_reinit_subscription为,默认值为 0.

  • 0 指定对项目所做的更改不会导致重新初始化订阅。 如果该存储过程检测到更改将需要重新初始化订阅,则会发生错误,并且不进行任何更改。
  • 1 指定对项目所做的更改会导致现有订阅重新初始化,并授予订阅重新初始化的权限。

[ @publisher = ] N'publisher'

指定非 SQL Server 发布服务器。 @publisher为 sysname,默认值为 NULL.

从 SQL Server 发布服务器发布时,不应使用@publisher。

[ @refreshsynctranprocs = ] refreshsynctranprocs

指定是否自动重新创建用于同步复制的存储过程。 @refreshsynctranprocs为,默认值为 1.

  • 1 表示重新创建存储过程。
  • 0 表示不会重新创建存储过程。

[ @internal = ] internal

标识为仅供参考。 不支持。 不保证以后的兼容性。

返回代码值

0(成功)或 1(失败)。

注解

sp_articleview创建定义已发布项目的视图,并将此视图sync_objid的 ID 插入 sysarticles 表的列中,并在列中插入限制子句filter_clause的文本。 如果复制所有列且没有列,sync_objid则 sysarticles 表中的 ID 设置为基表的 ID,并且不需要使用sp_articleviewfilter_clause

若要发布垂直筛选表(即筛选列),请先运行且不带@sync_object参数,对要复制的每个列运行sp_addarticle一次sp_articlecolumn(定义垂直筛选器),然后运行sp_articleview以创建定义已发布项目的视图。

若要发布水平筛选表(即筛选行),请运行 sp_addarticle ,不 带@filter_name 参数。 运行 sp_articlefilter,提供所有参数,包括 @filter_clause。 然后运行 sp_articleview,提供所有参数,包括相同的 @filter_clause

若要发布垂直和水平筛选表,请运行带@sync_object@filter_name参数的sp_addarticle。 对要复制的每个列运行 sp_articlecolumn 一次,然后运行 sp_articlefiltersp_articleview

如果项目已有定义已发布项目的视图, sp_articleview 请删除现有视图并自动创建一个新视图。 如果视图是手动创建的(type在 sysarticles5),则不会删除现有视图。

如果创建自定义筛选器存储过程和定义已发布项目的视图,请不要运行 sp_articleview。 而是将这些值作为@filter_name和@sync_object参数提供给sp_addarticle,以及相应的@type值。

示例

DECLARE @publication    AS sysname;
DECLARE @table AS sysname;
DECLARE @filterclause AS nvarchar(500);
DECLARE @filtername AS nvarchar(386);
DECLARE @schemaowner AS sysname;
SET @publication = N'AdvWorksProductTran'; 
SET @table = N'Product';
SET @filterclause = N'[DiscontinuedDate] IS NULL'; 
SET @filtername = N'filter_out_discontinued';
SET @schemaowner = N'Production';

-- Add a horizontally and vertically filtered article for the Product table.
-- Manually set @schema_option to ensure that the Production schema 
-- is generated at the Subscriber (0x8000000).
EXEC sp_addarticle 
    @publication = @publication, 
    @article = @table, 
    @source_object = @table,
    @source_owner = @schemaowner, 
    @schema_option = 0x80030F3,
    @vertical_partition = N'true', 
    @type = N'logbased',
    @filter_clause = @filterclause;

-- (Optional) Manually call the stored procedure to create the 
-- horizontal filtering stored procedure. Since the type is 
-- 'logbased', this stored procedures is executed automatically.
EXEC sp_articlefilter 
    @publication = @publication, 
    @article = @table, 
    @filter_clause = @filterclause, 
    @filter_name = @filtername;

-- Add all columns to the article.
EXEC sp_articlecolumn 
    @publication = @publication, 
    @article = @table;

-- Remove the DaysToManufacture column from the article
EXEC sp_articlecolumn 
    @publication = @publication, 
    @article = @table, 
    @column = N'DaysToManufacture', 
    @operation = N'drop';

-- (Optional) Manually call the stored procedure to create the 
-- vertical filtering view. Since the type is 'logbased', 
-- this stored procedures is executed automatically.
EXEC sp_articleview 
    @publication = @publication, 
    @article = @table,
    @filter_clause = @filterclause;
GO

权限

只有 sysadmin 固定服务器角色的成员db_owner固定数据库角色的成员才能执行sp_articleview