병합 게시에 대한 호환성 수준 설정

적용 대상:SQL Server

이 항목에서는 SQL Server Management Studio 또는 Transact-SQL을 사용하여 SQL Server에서 병합 게시의 호환성 수준을 설정하는 방법을 설명합니다. 병합 복제는 게시 호환성 수준을 사용하여 지정된 데이터베이스에서 게시에 사용할 수 있는 기능을 확인합니다.

항목 내용

SQL Server Management Studio 사용

새 게시 마법사의 구독자 유형 페이지에서 호환성 수준을 설정합니다. 이 마법사에 액세스하는 방법에 대한 자세한 내용은 게시 만들기를 참조하세요. 게시 스냅샷 만든 후에는 호환성 수준을 높일 수 있지만 줄일 수는 없습니다. 게시 속성 - <게시> 대화 상자의 일반 페이지에서 호환성 수준을 높입니다. 이 대화 상자에 액세스하는 방법은 게시 속성 보기 및 수정을 참조하세요. 게시 호환성 수준을 높이면 호환성 수준 이전 버전을 실행하는 서버의 기존 구독은 더 이상 동기화할 수 없습니다.

참고 항목

호환성 수준은 다른 게시 속성 및 유효한 아티클 속성을 결정하는 데에도 의미를 가지므로 대화 상자를 동일하게 사용할 때는 호환성 수준 및 다른 속성을 변경하지 마세요. 속성이 변경된 후 게시에 대한 스냅샷 다시 생성해야 합니다.

게시 호환성 수준을 설정하려면

  • 새 게시 마법사의 구독자 유형 페이지에서 게시에서 지원해야 하는 구독자 유형을 선택합니다.

게시 호환성 수준을 증가시키려면

  • 게시 속성 - <게시> 대화 상자의 일반 페이지에서 호환성 수준을 선택합니다.

Transact-SQL 사용

병합 게시의 호환성 수준은 나중에 게시를 만들거나 프로그래밍 방식으로 수정할 때 프로그래밍 방식으로 설정할 수 있습니다. 복제본(replica)tion 저장 프로시저를 사용하여 이 게시 속성을 설정하거나 변경할 수 있습니다.

병합 게시에 대한 게시 호환성 수준을 설정하려면

  1. 게시자에서 sp_addmergepublication(Transact-SQL)를 실행하여 게시를 이전 버전의 Microsoft SQL Server와 호환되도록 하는 값을 @publication_compatibility_level 지정합니다. 자세한 내용은 게시 만들기를 참조하세요.

병합 게시의 게시 호환성 수준을 변경하려면

  1. sp_changemergepublication(Transact-SQL)를 실행하여 publication_compatibility_level@property 및 적절한 게시 호환성 수준을 @value지정합니다.

병합 게시의 게시 호환성 수준을 확인하려면

  1. 원하는 게시를 지정하여 sp_helpmergepublication(Transact-SQL)를 실행합니다.

  2. 결과 집합의 backward_comp_level 열에서 게시 호환성 수준을 찾습니다.

예제(Transact-SQL)

다음은 병합 게시를 만들고 게시 호환성 수준을 설정하는 예제입니다.

-- To avoid storing the login and password in the script file, the values   
-- are passed into SQLCMD as scripting variables. 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 @login AS sysname;
DECLARE @password AS sysname;
SET @publicationDB = N'AdventureWorks2022';
SET @publication = N'AdvWorksSalesOrdersMerge';
SET @login = $(Login);
SET @password = $(Password);

-- Create a new merge publication.   
USE [AdventureWorks2022];
EXEC sp_addmergepublication
    @publication = @publication,
    -- Set the compatibility level to SQL Server 2014.  
    @publication_compatibility_level = '120RTM';

-- Create the snapshot job for the publication.  
EXEC sp_addpublication_snapshot
    @publication = @publication,
    @job_login = @login,
    @job_password = @password;
GO

다음 예에서는 병합 게시에 대한 게시 호환성 수준을 변경합니다.

참고 항목

게시에서 특정 호환성 수준이 필요한 기능을 사용하는 경우 게시 호환성 수준을 변경할 수 없습니다. 자세한 내용은 복제 이전 버전과의 호환성을 참조 하세요.

DECLARE @publication AS sysname;
SET @publication = N'AdvWorksSalesOrdersMerge';

-- Change the publication compatibility level to   
-- SQL Server 2008 or later.
EXEC sp_changemergepublication
    @publication = @publication,
    @property = N'publication_compatibility_level',
    @value = N'100RTM';
GO  
  

다음은 병합 게시의 현재 게시 호환성 수준을 반환하는 예제입니다.

DECLARE @publication AS sysname;
SET @publication = N'AdvWorksSalesOrdersMerge';
EXEC sp_helpmergepublication
    @publication = @publication;
GO

참고 항목

게시 만들기