sp_articlecolumn (Transact-SQL)

Область применения: yesSQL Server (все поддерживаемые версии)

Используется для указания столбцов, включенных в статью, для вертикальной фильтрации данных в опубликованной таблице. Эта хранимая процедура выполняется на издателе в базе данных публикации.

Topic link iconСинтаксические обозначения в Transact-SQL

Синтаксис

  
sp_articlecolumn [ @publication = ] 'publication'  
        , [ @article = ] 'article'  
    [ , [ @column = ] 'column' ]  
    [ , [ @operation = ] 'operation' ]  
    [ , [ @refresh_synctran_procs = ] refresh_synctran_procs ]  
    [ , [ @ignore_distributor = ] ignore_distributor ]  
    [ , [ @change_active = ] change_actve ]  
    [ , [ @force_invalidate_snapshot = ] force_invalidate_snapshot ]  
    [ , [ @force_reinit_subscription = ] force_reinit_subscription ]  
    [ , [ @publisher = ] 'publisher' ]  
    [ , [ @internal = ] 'internal' ]  

Аргументы

[ @publication = ] 'publication' Имя публикации, содержащей эту статью. публикацияsysname без значения по умолчанию.

[ @article = ] 'article' Имя статьи. статьяsysname без значения по умолчанию.

[ @column = ] 'column' Имя добавляемого или удаляемого столбца. столбецsysname с значением NULL по умолчанию. Если значение равно NULL, публикуются все столбцы.

[ @operation = ] 'operation' Указывает, следует ли добавлять или удалять столбцы в статье. операцияnvarchar(5) с добавлением по умолчанию. добавьте пометку столбца для репликации. удаляет метки столбца.

[ @refresh_synctran_procs = ] refresh_synctran_procs Указывает, создаются ли хранимые процедуры, поддерживающие немедленное обновление подписок, в соответствии с количеством реплицируемых столбцов. refresh_synctran_procsбит с значением по умолчанию 1. Если значение 1, хранимые процедуры создаются повторно.

[ @ignore_distributor = ] ignore_distributor Указывает, выполняется ли эта хранимая процедура без подключения к распространителю. ignore_distributorбит с значением по умолчанию 0. Если значение 0, база данных должна быть включена для публикации, а кэш статей должен быть обновлен, чтобы отразить новые столбцы, реплицированные в статье. Если значение 1, позволяет удалять столбцы статей для статей, находящихся в неопубликованной базе данных; следует использовать только в ситуациях восстановления.

[ @change_active = ] change_active Позволяет изменять столбцы в публикациях с подписками. change_active — это целое число с значением по умолчанию 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 = ] 'publisher' Указывает издатель, отличный от Microsoft SQL Server. Publishersysname с значением NULL по умолчанию.

Примечание

издатель не должен использоваться с издателем SQL Server.

[ @internal = ] 'internal' Только внутреннее использование.

Значения кода возврата

0 (успешно) или 1 (сбой)

Remarks

sp_articlecolumn используется в репликации моментальных снимков и репликации транзакций.

С помощью sp_articlecolumn можно отфильтровать только статью без подписки.

Пример

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_articlecolumn.

См. также

Определение статьи
Определение и изменение фильтра столбцов
Фильтрация опубликованных данных
sp_addarticle (Transact-SQL)
sp_articleview (Transact-SQL)
sp_changearticle (Transact-SQL)
sp_droparticle (Transact-SQL)
sp_helparticle (Transact-SQL)
sp_helparticlecolumns (Transact-SQL)
Хранимые процедуры репликации (Transact-SQL)