sp_articlecolumn (Transact-SQL)
Применимо к:SQL Server
Используется для указания столбцов, включенных в статью, для вертикальной фильтрации данных в опубликованной таблице. Эта хранимая процедура выполняется на издателе в базе данных публикации.
Соглашения о синтаксисе 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'
Имя публикации, содержащей эту статью. параметр publication имеет значение sysname без значения по умолчанию.
[ @article = ] 'article'
Имя статьи. article имеет значение sysname без значения по умолчанию.
[ @column = ] 'column'
Имя добавляемого или удаляемого столбца. column имеет значение sysname, значение по умолчанию — NULL. Если значение равно NULL, публикуются все столбцы.
[ @operation = ] 'operation'
Указывает, следует ли добавлять или удалять столбцы в статье. параметр operation имеет значение nvarchar(5) с значением по умолчанию add. add помечает столбец для репликации. функция drop отменяет пометку столбца.
[ @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 является 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 = ] 'publisher'
Указывает издателя SQL Server, отличного от Корпорации Майкрософт. publisher имеет значение sysname, значение по умолчанию — NULL.
Примечание
Publisher не следует использовать с издателем SQL Server.
[ @internal = ] 'internal'
Только для внутреннего использования.
Значения кода возврата
0 (успешно) или 1 (сбой)
Комментарии
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)
Обратная связь
Отправить и просмотреть отзыв по