sp_adddynamicsnapshot_job(Transact-SQL)
적용 대상: SQL Server Azure SQL Managed Instance
매개 변수가 있는 행 필터를 사용하여 게시에 대해 필터링된 데이터 스냅샷을 생성하는 에이전트 작업을 만듭니다. 이 저장 프로시저는 게시 데이터베이스의 게시자에서 실행됩니다. 이 저장 프로시저는 관리자가 구독자에 대해 필터링된 데이터 스냅샷 작업을 수동으로 만드는 데 사용됩니다.
참고 항목
필터링된 데이터 스냅샷 작업을 만들려면 게시에 대한 표준 스냅샷 작업이 있어야 합니다.
자세한 내용은 매개 변수가 있는 필터로 병합 게시에 대한 스냅샷 만들기를 참조하세요.
구문
sp_adddynamicsnapshot_job
[ @publication = ] N'publication'
[ , [ @suser_sname = ] N'suser_sname' ]
[ , [ @host_name = ] N'host_name' ]
[ , [ @dynamic_snapshot_jobname = ] N'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 ]
[ ; ]
인수
[ @publication = ] N'publication'
필터링된 데이터 스냅샷 작업이 추가되는 게시의 이름입니다. @publication 기본값이 없는 sysname입니다.
[ @suser_sname = ] N'suser_sname'
구독자에서 SUSER_SNAME 함수의 값으로 필터링되는 구독에 대해 필터링된 데이터 스냅샷을 만들 때 사용되는 값입니다. @suser_sname sysname이며 기본값은 .입니다NULL
. @suser_sname 이 함수가 게시를 동적으로 필터링하는 데 사용되지 않는 경우여야 합니다NULL
.
[ @host_name = ] N'host_name'
구독자의 HOST_NAME 함수 값으로 필터링되는 구독에 대해 필터링된 데이터 스냅샷을 만들 때 사용되는 값입니다. @host_name sysname이며 기본값은 .입니다NULL
. host_name 이 함수가 게시를 동적으로 필터링하는 데 사용되지 않는 경우여야 합니다NULL
.
[ @dynamic_snapshot_jobname = ] N'dynamic_snapshot_jobname' OUTPUT
생성된 필터링된 데이터 스냅샷 작업의 이름입니다. @dynamic_snapshot_jobname sysname 형식의 OUTPUT 매개 변수입니다. 지정된 경우 @dynamic_snapshot_jobname 배포자에서 고유한 작업으로 확인되어야 합니다. 지정하지 않으면 다음과 같이 이름이 만들어지는 결과 집합에서 작업 이름이 자동으로 생성됩니다.
'dyn_' + <name of the standard snapshot job> + <GUID>
참고 항목
동적 스냅샷 작업의 이름을 생성할 때 표준 스냅샷 작업의 이름을 자를 수 있습니다.
[ @dynamic_snapshot_jobid = ] 'dynamic_snapshot_jobid' OUTPUT
생성된 필터링된 데이터 스냅샷 작업의 식별자입니다. @dynamic_snapshot_jobid 기본값NULL
인 uniqueidentifier 형식의 OUTPUT 매개 변수입니다.
[ @frequency_type = ] frequency_type
필터링된 데이터 스냅샷 작업이 예약되는 빈도를 지정합니다. @frequency_type int이며 이러한 값 중 하나일 수 있습니다.
값 | 설명 |
---|---|
1 |
한 번 |
2 (기본값) |
주문형 |
4 |
매일 |
8 |
매주 |
16 |
매월 |
32 |
월별 상대 |
64 |
자동 시작 |
128 |
되풀이 |
[ @frequency_interval = ] frequency_interval
필터링된 데이터 스냅샷 작업이 실행되는 기간(일)입니다. @frequency_interval int이며 @frequency_type 값에 따라 달라집니다.
@frequency_type 값 | @frequency_interval 영향 |
---|---|
1 (기본값) |
@frequency_interval 사용되지 않습니다. |
4 |
@frequency_interval 일마다. |
8 |
@frequency_interval 다음 중 하나 이상입니다(| (비트 OR) 논리 연산자:1 = 일요일2 = 월요일4 = 화요일8 = 수요일16 = 목요일32 = 금요일64 = 토요일 |
16 |
해당 월의 @frequency_interval 일입니다. |
32 |
@frequency_interval 다음 옵션 중 하나입니다.1 = 일요일2 = 월요일3 = 화요일4 = 수요일5 = 목요일6 = 금요일7 = 토요일8 = 일9 = 평일10 = 주말 |
64 |
@frequency_interval 사용되지 않습니다. |
128 |
@frequency_interval 사용되지 않습니다. |
[ @frequency_subday = ] frequency_subday
@frequency_subday_interval 단위를 지정합니다. @frequency_subday int이며 이러한 값 중 하나일 수 있습니다.
값 | 설명 |
---|---|
1 (기본값) |
한 번 |
2 |
둘째 |
4 |
Minute |
8 |
Hour |
[ @frequency_subday_interval = ] frequency_subday_interval
작업의 각 실행 사이에 발생하는 frequency_subday 기간의 수입니다. @frequency_subday_interval 기본값1
인 int입니다.
[ @frequency_relative_interval = ] frequency_relative_interval
매달 필터링된 데이터 스냅샷 작업의 발생입니다. 이 매개 변수는 @frequency_type (월별 상대)로 설정 될 32
때 사용 됩니다. @frequency_relative_interval int이며 이러한 값 중 하나일 수 있습니다.
값 | 설명 |
---|---|
1 (기본값) |
첫 번째 |
2 |
두 번째 |
4 |
세 번째 |
8 |
네 번째 |
16 |
마지막 |
[ @frequency_recurrence_factor = ] frequency_recurrence_factor
frequency_type 사용되는 되풀이 요소입니다. @frequency_recurrence_factor 기본값1
인 int입니다.
[ @active_start_date = ] active_start_date
필터링된 데이터 스냅샷 작업이 처음 예약되고 형식 yyyyMMdd
이 지정된 날짜입니다. @active_start_date 기본값0
인 int입니다.
[ @active_end_date = ] active_end_date
필터링된 데이터 스냅샷 작업이 예약되지 않고 형식이 yyyyMMdd
지정된 날짜입니다. @active_end_date 기본값0
인 int입니다.
[ @active_start_time_of_day = ] active_start_time_of_day
필터링된 데이터 스냅샷 작업이 처음 예약된 시간이며 형식은 다음과 같습니다 HHmmss
. @active_start_time_of_day 기본값0
인 int입니다.
[ @active_end_time_of_day = ] active_end_time_of_day
필터링된 데이터 스냅샷 작업이 예약되지 않고 형식 HHmmss
이 지정된 하루 중 시간입니다. @active_end_time_of_day 기본값0
인 int입니다.
결과 집합
열 이름 | 데이터 형식 | 설명 |
---|---|---|
id |
int | MSdynamicsnapshotjobs 시스템 테이블에서 필터링된 데이터 스냅샷 작업을 식별합니다. |
dynamic_snapshot_jobname |
sysname | 필터링된 데이터 스냅샷 작업의 이름입니다. |
dynamic_snapshot_jobid |
uniqueidentifier | 배포자에서 SQL Server 에이전트 작업을 고유하게 식별합니다. |
반환 코드 값
0
(성공) 또는 1
(실패).
설명
sp_adddynamicsnapshot_job
는 매개 변수가 있는 필터를 사용하는 게시에 대한 병합 복제에 사용됩니다.
예제
-- 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'AdventureWorks2022';
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 [AdventureWorks2022];
-- Enable AdventureWorks2022 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 AdventureWorks2022.',
@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
사용 권한
sysadmin 고정 서버 역할 또는 db_owner 고정 데이터베이스 역할의 멤버만 실행할 sp_adddynamicsnapshot_job
수 있습니다.