sp_adddynamicsnapshot_job (Transact-SQL)
Cria um trabalho de agente que gera um instantâneo de dados filtrado para uma publicação com filtros de linha com parâmetros. Esse procedimento armazenado é executado no Publicador, no banco de dados publicador. Esse procedimento armazenado é usado por um administrador para criar trabalhos de instantâneo de dados manualmente filtrados para Assinantes.
Dica
Para que um trabalho de instantâneo de dados filtrados seja criado, um trabalho de instantâneo padrão para a publicação deve existir.
Para obter mais informações, consulte Instantâneos para publicações de mesclagem com filtros com parâmetros.
Convenções da sintaxe Transact-SQL
Sintaxe
sp_adddynamicsnapshot_job [ @publication = ] 'publication'
[ , [ @suser_sname = ] 'suser_sname' ]
[ , [ @host_name = ] 'host_name' ]
[ , [ @dynamic_snapshot_jobname = ] 'dynamic_snapshot_jobname' OUTPUT ]
[ , [ @dynamic_snapshot_jobid = ] 'dynamic_snapshot_jobid' OUTPUT ]
[ , [ @frequency_type= ] frequency_type ]
[ , [ @frequency_interval= ] frequency_interval ]
[ , [ @frequency_subday= ] frequency_subday ]
[ , [ @frequency_subday_interval= ] frequency_subday_interval ]
[ , [ @frequency_relative_interval= ] frequency_relative_interval ]
[ , [ @frequency_recurrence_factor= ] frequency_recurrence_factor ]
[ , [ @active_start_date= ] active_start_date ]
[ , [ @active_end_date= ] active_end_date ]
[ , [ @active_start_time_of_day= ] active_start_time_of_day ]
[ , [ @active_end_time_of_day= ] active_end_time_of_day ]
Argumentos
[ @publication=] 'publication'
É o nome da publicação à qual o trabalho de instantâneo de dados filtrados está sendo adicionado. publication é sysname, sem padrão.[ @suser_sname= ] 'suser_sname'
É o valor usado ao criar um instantâneo de dados filtrados para uma assinatura filtrada pelo valor da função SUSER_SNAME no Assinante. suser_sname é sysname, sem padrão. suser_sname deverá ser NULL se essa função não for usada para filtrar dinamicamente a publicação.[ @host_name= ] 'host_name'
É o valor usado ao criar um instantâneo de dados filtrados para uma assinatura filtrada pelo valor da função HOST_NAME no Assinante. host_name é sysname, sem padrão. host_name deverá ser NULL se essa função não for usada para filtrar dinamicamente a publicação.[ @dynamic_snapshot_jobname= ] 'dynamic_snapshot_jobname'
É o nome do trabalho de instantâneo de dados filtrados criado. dynamic_snapshot_jobname é sysname, com um padrão de NULL, e é um parâmetro opcional de OUTPUT. Se especificado, dynamic_snapshot_jobname deve resolver para um trabalho único no Distribuidor. Se não for especificado, um nome de trabalho será automaticamente gerado e retornado no conjunto de resultados, onde o nome será criado como segue:'dyn_' + <name of the standard snapshot job> + <GUID>
Dica
Ao gerar o nome do trabalho de instantâneo dinâmico, você pode truncar o nome do trabalho de instantâneo padrão.
[ @dynamic_snapshot_jobid= ] 'dynamic_snapshot_jobid'
É um identificador do trabalho de instantâneo de dados filtrados criado. dynamic_snapshot_jobid é uniqueidentifier, com um padrão de NULL, e é um parâmetro opcional de OUTPUT.[ @frequency_type=] frequency_type
É a frequência do agendamento do trabalho de instantâneo de dados filtrados. frequency_type é int, e pode ter um destes valores.Valor
Descrição
1
Uma vez
2
Sob demanda
4 (padrão)
Diariamente
8
Semanalmente
16
Mensalmente
32
Relativo ao mês
64
Iniciar automaticamente
128
Recorrente
[ @frequency_interval = ] frequency_interval
É o período (medido em dias) quando o trabalho de instantâneo de dados filtrados é executado. frequency_interval é int, com um valor padrão de 1, e depende do valor de frequency_type.Valor de frequency_type
Efeito em frequency_interval
1
frequency_interval não é usado.
4 (padrão)
Cada dia de frequency_interval, com um padrão diário.
8
frequency_interval é um ou mais dos seguintes (combinado com um operador lógico | (OR bit a bit) (Transact-SQL)):
1 = Domingo | 2 = Segunda-feira | 4 = Terça-feira | 8 = Quarta-feira | 16 = Quinta-feira | 32 = Sexta-feira | 64 = Sábado
16
No dia do freq_interval do mês.
32
frequency_interval é um dos seguintes:
1 = Domingo | 2 = Segunda-feira | 3 = Terça-feira | 4 = Quarta-feira | 5 = Quinta-feira | 6 = Sexta-feira | 7 = Sábado | 8 = Dia | 9 = Dia da semana | 10 = Dia do fim de semana
64
frequency_interval não é usado.
128
frequency_interval não é usado.
[ @frequency_subday=] frequency_subday
Especifica as unidades de frequency_subday_interval. frequency_subday é int, e pode ter um destes valores.Valor
Descrição
1
Uma vez
2
Segundo
4 (padrão)
Minuto
8
Hora
[ @frequency_subday_interval=] frequency_subday_interval
É o número de períodos de frequency_subday que ocorrem entre cada execução do trabalho. frequency_subday_interval é int, com um padrão de 5.[ @frequency_relative_interval=] frequency_relative_interval
É a ocorrência do trabalho de instantâneo de dados filtrado em cada mês. Esse parâmetro é usado quando frequency_type está definido como 32 (mensal relativo). frequency_relative_interval é int, e pode ter um destes valores.Valor
Descrição
1 (padrão)
Primeiro
2
Segundo
4
Terceiro
8
Quarto
16
Último
[ @ frequency_recurrence_factor =] frequency_recurrence_factor
É o fator de recorrência usado por frequency_type. frequency_recurrence_factor é int, com um padrão de 0.[ @active_start_date=] active_start_date
É a data do primeiro agendamento do trabalho de instantâneo de dados filtrados, formatada como AAAAMMDD. active_start_date é int, com um padrão de NULL.[ @active_end_date=] active_end_date
É a data do último agendamento do trabalho de instantâneo de dados filtrados, formatada como AAAAMMDD. active_end_date é int, com um padrão de NULL.[ @active_start_time_of_day=] active_start_time_of_day
É a hora do dia do primeiro agendamento do trabalho de instantâneo de dados filtrados, formatada como HHMMSS. active_start_time_of_day é int, com um padrão de NULL.[ @active_end_time_of_day=] active_end_time_of_day
É a hora do dia do primeiro agendamento do trabalho de instantâneo de dados filtrados, formatada como HHMMSS. active_end_time_of_day é int, com um padrão de NULL.
Conjunto de resultados
Nome da coluna |
Tipo de dados |
Descrição |
---|---|---|
id |
int |
Identifica o trabalho de instantâneo de dados filtrado na tabela do sistema MSdynamicsnapshotjobs. |
dynamic_snapshot_jobname |
sysname |
Nome do trabalho de instantâneo de dados filtrado. |
dynamic_snapshot_jobid |
uniqueidentifier |
Identifica com exclusividade o MicrosoftSQL Server Agent no Distribuidor. |
Valores de código de retorno
0 (êxito) ou 1 (falha)
Comentários
sp_adddynamicsnapshot_job é usado em replicação de mesclagem para publicações que usam um filtro com parâmetros.
Exemplo
-- To avoid storing the login and password in the script file, the value
-- is passed into SQLCMD as a scripting variable. For information about
-- how to use scripting variables on the command line and in SQL Server
-- Management Studio, see the "Executing Replication Scripts" section in
-- the topic "Programming Replication Using System Stored Procedures".
--Add a new merge publication.
DECLARE @publicationdb AS sysname;
DECLARE @publication AS sysname;
DECLARE @table1 AS sysname;
DECLARE @table2 AS sysname;
DECLARE @filter AS sysname;
DECLARE @schema_hr AS sysname;
DECLARE @schema_sales AS sysname;
SET @publicationdb = N'AdventureWorks2012';
SET @publication = N'AdvWorksSalesPersonMerge';
SET @table1 = N'Employee';
SET @table2 = N'SalesPerson';
SET @filter = N'SalesPerson_Employee';
SET @schema_hr = N'HumanResources';
SET @schema_sales = N'Sales';
USE [AdventureWorks2012];
-- Enable AdventureWorks2012 for merge replication.
EXEC sp_replicationdboption
@dbname = @publicationdb,
@optname = N'merge publish',
@value = N'true';
-- Create new merge publication.
EXEC sp_addmergepublication
@publication = @publication,
@description = N'Merge publication of AdventureWorks2012.',
@allow_subscriber_initiated_snapshot = N'false';
-- Create a new snapshot job for the publication, using the
-- default schedule. Pass credentials at runtime using
-- sqlcmd scripting variables.
EXEC sp_addpublication_snapshot
@publication = @publication,
@job_login = $(Login),
@job_password = $(password);
-- Add an article for the Employee table,
-- which is horizontally partitioned using
-- a parameterized row filter.
EXEC sp_addmergearticle
@publication = @publication,
@article = @table1,
@source_owner = @schema_hr,
@source_object = @table1,
@type = N'table',
@description = 'contains employee information',
@subset_filterclause = N'[LoginID] = HOST_NAME()';
-- Add an article for the SalesPerson table,
-- which is partitioned based on a join filter.
EXEC sp_addmergearticle
@publication = @publication,
@article = @table2,
@source_owner = @schema_sales,
@source_object = @table2,
@type = N'table',
@description = 'contains customer information';
-- Add a join filter between the two articles.
EXEC sp_addmergefilter
@publication = @publication,
@article = @table1,
@filtername = @filter,
@join_articlename = @table2,
@join_filterclause = N'[Employee].[BusinessEntityID] = [SalesPerson].[SalesPersonID]',
@join_unique_key = 1,
@filter_type = 1;
GO
-- Start the snapshot agent job.
DECLARE @publication AS sysname;
SET @publication = N'AdvWorksSalesPersonMerge';
EXEC sp_startpublication_snapshot
@publication = @publication;
GO
PRINT '*** Waiting for the initial snapshot.';
GO
-- Create a temporary table to store the filtered data snapshot
-- job information.
CREATE TABLE #temp (id int,
job_name sysname,
job_id uniqueidentifier,
dynamic_filter_login sysname NULL,
dynamic_filter_hostname sysname NULL,
dynamic_snapshot_location nvarchar(255),
frequency_type int,
frequency_interval int,
frequency_subday_type int,
frequency_subday_interval int,
frequency_relative_interval int,
frequency_recurrence_factor int,
active_start_date int,
active_end_date int,
active_start_time int,
active_end_time int
)
-- Create each snapshot for a partition
-- The initial snapshot must already be generated.
DECLARE @publication AS sysname;
DECLARE @jobname AS sysname
DECLARE @hostname AS sysname
SET @publication = N'AdvWorksSalesPersonMerge';
SET @hostname = N'adventure-works\Fernando';
WHILE NOT EXISTS(SELECT * FROM sysmergepublications
WHERE [name] = @publication
AND snapshot_ready = 1)
BEGIN
WAITFOR DELAY '00:00:05'
END
-- Create a data partition by overriding HOST_NAME().
EXEC sp_addmergepartition
@publication = @publication,
@host_name = @hostname;
-- Create the filtered data snapshot job, and use the returned
-- information to start the job.
EXEC sp_adddynamicsnapshot_job
@publication = @publication,
@host_name = @hostname;
INSERT INTO #temp (id, job_name, job_id, dynamic_filter_login,
dynamic_filter_hostname, dynamic_snapshot_location,
frequency_type, frequency_interval, frequency_subday_type,
frequency_subday_interval, frequency_relative_interval,
frequency_recurrence_factor, active_start_date, active_end_date,
active_start_time,active_end_time)
EXEC sp_helpdynamicsnapshot_job;
SELECT @jobname = (SELECT DISTINCT job_name FROM #temp WHERE dynamic_filter_hostname = @hostname);
EXEC msdb..sp_start_job @job_name = @jobname;
DROP TABLE #temp;
GO
Permissões
Somente membros da função de servidor fixa sysadmin ou da função de banco de dados fixa db_owner podem executar sp_adddynamicsnapshot_job.
Consulte também
Referência
sp_dropdynamicsnapshot_job (Transact-SQL)
sp_helpdynamicsnapshot_job (Transact-SQL)
Conceitos
Criar um instantâneo para uma publicação de mesclagem com filtros com parâmetros