다음을 통해 공유


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

적용 대상: SQL Server

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

항목 내용

SQL Server Management Studio 사용

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

참고 항목

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

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

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

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

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

Transact-SQL 사용

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

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

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

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

  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

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

참고 항목

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

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