sp_articleview (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'
包含项目的发布的名称。 @publication 为 sysname,无默认值。
[ @article = ] N'article'
项目的名称。 @article 为 sysname,无默认值。
[ @view_name = ] N'view_name'
定义已发布项目的视图的名称。 @view_name 为 nvarchar(386),默认值为 NULL
.
[ @filter_clause = ] N'filter_clause'
定义水平筛选器的限制 (WHERE
) 子句。 输入限制子句时,省略 WHERE
关键字。 @filter_clause 为 nvarchar(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 (Transact-SQL) 表的列中,并在列中插入限制子句filter_clause
的文本。 如果复制所有列且没有 filter_clause
列,则 sync_objid
sysarticles (Transact-SQL) 表中的 ID 设置为基表的 ID,并且不需要使用 sp_articleview
。
若要发布垂直筛选表(即筛选列),请先运行且不带@sync_object参数,对要复制的每个列运行sp_addarticle
一次sp_articlecolumn(Transact-SQL),然后运行sp_articleview
以创建定义已发布项目的视图。
若要发布水平筛选表(即筛选行),请运行 sp_addarticle(Transact-SQL), 不 带@filter_name 参数。 运行sp_articlefilter(Transact-SQL),提供包括@filter_clause在内的所有参数。 然后运行 sp_articleview
,提供所有参数,包括相同的 @filter_clause。
若要发布垂直和水平筛选表,请运行不带@sync_object或@filter_name参数的sp_addarticle(Transact-SQL)。 对要复制的每个列运行 一次sp_articlecolumn(Transact-SQL), 然后运行 sp_articlefilter(Transact-SQL) 和 sp_articleview
。
如果项目已有定义已发布项目的视图, sp_articleview
请删除现有视图并自动创建一个新视图。 如果视图是手动创建的(type
在 sysarticles(Transact-SQL)5
中),则不会删除现有视图。
如果创建自定义筛选器存储过程和定义已发布项目的视图,请不要运行 sp_articleview
。 而是将这些值作为@filter_name和@sync_object参数提供给 sp_addarticle (Transact-SQL),以及相应的@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
。