매개 변수가 있는 행 필터 최적화

적용 대상:SQL Server

이 항목에서는 SQL Server Management Studio 또는 Transact-SQL을 사용하여 SQL Server에서 매개 변수가 있는 행 필터를 최적화하는 방법을 설명합니다.

항목 내용

시작하기 전에

권장 사항

  • 매개 변수가 있는 필터를 사용하는 경우 게시를 만들 때 파티션 그룹 사용 옵션 또는 파티션 변경 내용 유지 옵션을 지정하여 병합 복제본(replica)tion에서 필터를 처리하는 방법을 제어할 수 있습니다. 이러한 옵션은 게시 데이터베이스에 추가 메타데이터를 저장하여 필터링된 아티클을 사용하여 게시의 동기화 성능을 향상시킵니다. 아티클을 만들 때 파티션 옵션을 설정하여 구독자 간에 데이터를 공유하는 방법을 제어할 수 있습니다. 이러한 요구 사항에 대한 자세한 내용은 매개 변수가 있는 행 필터를 참조 하세요.

    SQL Server CompactSQL Server Compact 구독자를 사용하면 삭제가 올바르게 전파되도록 keep_partition_changes true로 설정해야 합니다. false로 설정하면 구독자에 예상보다 많은 행이 있을 수 있습니다.

SQL Server Management Studio 사용

다음 설정을 사용하여 매개 변수가 있는 행 필터를 최적화할 수 있습니다.

파티션 옵션
아티클 속성 - <아티>클 대화 상자의 속성 페이지 또는 필터 추가 대화 상자에서 이 옵션을 설정합니다. 새 게시 마법사와 게시 속성 - <> 게시 대화 상자에서 두 대화 상자를 모두 사용할 수 있습니다. 아티클 속성 - <아티클> 대화 상자를 사용하면 필터 추가 대화 상자에서 사용할 수 없는 이 옵션에 대한 추가 값을 지정할 수 있습니다.

파티션 사전 계산
게시의 아티클이 요구 사항 집합을 준수하는 경우 이 옵션은 기본적으로 True로 설정됩니다. 이러한 요구 사항에 대한 자세한 내용은 사전 계산 파티션으로 매개 변수가 있는 필터 성능 최적화를 참조하세요. 게시 속성 - <게시> 대화 상자의 구독 옵션 페이지에서 이 옵션을 수정합니다.

동기화 최적화
이 옵션은 사전 계산 파티션이 False로 설정된 경우에만 True설정해야 합니다. 게시 속성 - <게시> 대화 상자의 구독 옵션 페이지에서 이 옵션을 설정합니다.

새 게시 마법사를 사용하고 게시 속성 - <게시> 대화 상자에 액세스하는 방법에 대한 자세한 내용은 게시 만들기 및 보기 및 게시 속성 수정을 참조하세요.

필터 추가 또는 필터 편집 대화 상자에서 파티션 옵션을 설정하려면

  1. 새 게시 마법사의 테이블 행 필터 페이지 또는 게시 속성 - <게시> 대화 상자의 필터 페이지에서 추가를 클릭한 다음 필터 추가를 클릭합니다.

  2. 매개 변수가 있는 필터를 만듭니다. 자세한 내용은 병합 아티클에 대한 매개 변수가 있는 행 필터 정의 및 수정을 참조하세요.

  3. 구독자 간에 데이터를 공유하는 방법과 일치하는 옵션을 선택합니다.

    • 이 테이블의 행은 여러 구독으로 이동합니다.

    • 이 테이블의 행은 하나의 구독으로만 이동합니다.

    이 테이블에서 행을 선택하면 하나의 구독으로만 이동됩니다. 병합 복제본(replica)tion은 더 적은 메타데이터를 저장하고 처리하여 성능을 최적화할 수 있습니다. 그러나 한 행이 둘 이상의 구독자로 복제될 수 없도록 데이터가 분할되어야 합니다. 자세한 내용은 매개 변수가 있는 행 필터 항목 의 "파티션 옵션 설정" 섹션을 참조하세요.

  4. 확인을 선택합니다.

  5. 게시 속성 - <게시> 대화 상자에 있는 경우 [확인]을 클릭하여 대화 상자를 저장하고 닫습니다.

아티클 속성 - <아티> 클 대화 상자에서 파티션 옵션을 설정하려면

  1. 새 게시 마법사 또는 게시 속성 - <게시> 대화 상자의 아티클 페이지에서 표를 선택한 다음 아티클 속성을 클릭합니다.

  2. 강조 표시된 테이블 아티클의 속성 설정 또는 모든 테이블 아티의 속성 설정을 클릭합니다.

  3. 아티클 속성 - <아티클> 대화 상자의 속성 탭에 있는 대상 개체 섹션에서 파티션 옵션에 대해 다음 값 중 하나를 지정합니다.

    • 겹치는

    • 겹침, 파티션 외부 데이터 변경 허용 불가

    • 비오버랩, 단일 구독

    • 겹치지 않음, 구독 간 공유

    이러한 옵션 및 필터 추가 및 필터 편집 대화 상자에서 사용할 수 있는 옵션과 관련된 방법에 대한 자세한 내용은 매개 변수가 있는 행 필터"파티션 옵션 설정" 섹션을 참조하세요.

  4. 확인을 선택합니다.

  5. 게시 속성 - <게시> 대화 상자에 있는 경우 [확인]을 클릭하여 대화 상자를 저장하고 닫습니다.

사전 계산 파티션을 설정하려면

  1. 게시 속성 - <게시> 대화 상자의 구독 옵션 페이지에서 파티션 사전 계산 옵션의 값을 선택합니다. 다음과 같은 경우 이 속성은 읽기 전용입니다.

    • 게시가 사전 계산 파티션에 대한 요구 사항을 충족하지 않습니다.

    • 게시에 대한 스냅샷이 아직 생성되지 않았습니다. 이 경우 옵션은 스냅샷 만들 때 자동으로 Set 값을 표시합니다.

  2. 확인을 선택합니다.

동기화 최적화를 설정하려면

  1. 게시 속성 - <게시> 대화 상자의 구독 옵션 페이지에서 동기화 최적화 옵션의 True값을 선택합니다.

  2. 확인을 선택합니다.

Transact-SQL 사용

@keep_partition_changes@use_partition_groups에 대한 필터링 옵션의 정의는 sp_addmergepublication을 참조하세요.

새 게시를 만들 때 병합 필터 최적화를 지정하려면

  1. 게시 데이터베이스의 게시자에서 sp_addmergepublication 실행합니다. 다음 매개 변수 중 하나를 지정하고 값을 true 지정 @publication 합니다.

    • @use_partition_groups - 아티클이 사전 계산 파티션의 요구 사항을 충족하는 경우 가장 높은 성능 최적화를 제공합니다. 자세한 내용은 미리 계산된 파티션을 사용하여 매개 변수가 있는 필터 성능 최적화를 참조 하세요.

    • @keep_partition_changes - 사전 계산 파티션을 사용할 수 없는 경우 이 최적화를 사용합니다.

  2. 게시에 대한 스냅샷 작업을 추가합니다. 자세한 내용은 게시 만들기를 참조하세요.

  3. 게시 데이터베이스의 게시자에서 다음 매개 변수를 지정하여 sp_addmergearticle 실행합니다.

    • @publication - 1단계에서 만든 게시의 이름입니다.

    • @article - 문서의 이름

    • @source_object - 게시 중인 데이터베이스 개체입니다.

    • @subset_filterclause - 아티클을 가로로 필터링하는 데 사용되는 선택적 매개 변수가 있는 필터 절입니다.

    • @partition_options - 필터링된 아티클에 대한 파티션 옵션입니다.

  4. 발행물의 각 아티클에 대해 3단계를 반복합니다.

  5. (선택 사항) 게시 데이터베이스의 게시자에서 sp_addmergefilter 실행하여 두 아티클 간의 조인 필터를 정의합니다. 자세한 내용은 병합 아티클 간의 조인 필터 정의 및 수정을 참조 하세요.

기존 게시에 대한 병합 필터 동작을 보고 수정하려면

  1. (선택 사항) 게시 데이터베이스의 게시자에서 sp_helpmergepublication 실행하여 지정합니다@publication. 결과 집합의 keep_partition_changes 값과 use_partition_groups 결과 집합의 값을 확인합니다.

  2. (선택 사항) 게시 데이터베이스의 게시자에서 sp_changemergepublication 실행합니다. for 및 for의 use_partition_groups 값을 지정합니다 truefalse@value.@property

  3. (선택 사항) 게시 데이터베이스의 게시자에서 sp_changemergepublication 실행합니다. for 및 for의 keep_partition_changes 값을 지정합니다 truefalse@value.@property

    참고 항목

    사용하도록 설정할 keep_partition_changes때는 먼저 에 대한 @force_reinit_subscription값을 1 사용하지 않도록 설정하고 use_partition_groups 지정해야 합니다.

  4. (선택 사항) 게시 데이터베이스의 게시자에서 sp_changemergearticle 실행합니다. 에 대한 @propertypartition_options 과 적절한 값을 지정합니다@value. 이러한 필터링 옵션의 정의는 sp_addmergearticle 을 참조하십시오.

  5. (선택 사항) 필요한 경우 스냅샷 에이전트 시작하여 스냅샷 다시 생성합니다. 새 스냅샷 생성해야 하는 변경 내용에 대한 자세한 내용은 변경 게시 및 아티클 속성을 참조하세요.

참고 항목

병합 아티클 간의 조인 필터 집합 자동 생성(SQL Server Management Studio)
병합 아티클에 대한 매개 변수가 있는 행 필터 정의 및 수정
매개 변수가 있는 행 필터