다음을 통해 공유


전체 텍스트 인덱스 채우기

전체 텍스트 인덱스를 만들고 유지 관리하려면 채우기(탐색이라고도 함)라는 프로세스를 사용하여 인덱스를 채워야 합니다. SQL Server에서 지원하는 채우기 유형에는 전체 채우기, 변경 내용 추적 기반 자동 또는 수동 채우기 및 증분 타임스탬프 기반 채우기가 있습니다.

전체 채우기

전체 채우기 중에는 테이블 또는 인덱싱된 뷰의 모든 행에 대해 인덱스 항목이 작성됩니다. 전체 텍스트 인덱스의 전체 채우기는 기본 테이블 또는 인덱싱된 뷰의 모든 행에 대해 인덱스 항목을 작성합니다.

기본적으로 SQL Server는 새 전체 텍스트 인덱스를 만드는 즉시 채웁니다. 그러나 전체 채우기는 많은 양의 리소스를 사용할 수 있습니다. 따라서 리소스 사용량이 많을 때 전체 텍스트 인덱스를 만들 경우, 특히 전체 텍스트 인덱스의 기본 테이블이 클 경우 리소스 사용량이 많지 않을 때까지 전체 채우기를 지연시키는 것이 좋습니다. 그러나 인덱스가 속한 전체 텍스트 카탈로그는 전체 텍스트 인덱스가 모두 채워질 때까지 사용할 수 없습니다. 전체 텍스트 인덱스를 즉시 채우지 않고 만들려면 CREATE FULLTEXT INDEX Transact-SQL 문에 CHANGE_TRACKING OFF, NO POPULATION 절을 지정합니다. SQL Server에서는 사용자가 START FULL POPULATION 또는 START INCREMENTAL POPULATION 절을 사용하여 ALTER FULLTEXT INDEX Transact-SQL 문을 실행할 때까지 새로운 전체 텍스트 인덱스를 채우지 않습니다. 자세한 내용은 이 항목의 뒷부분에 나오는 예 "1. 전체 채우기를 실행하지 않고 전체 텍스트 인덱스 만들기" 및 "2. 테이블에 대해 전체 채우기 실행"을 참조하십시오.

변경 내용 추적 기반 채우기

경우에 따라 초기 전체 채우기 후에 변경 내용 추적을 사용하여 전체 텍스트 인덱스를 유지 관리할 수도 있습니다. SQL Server에서는 마지막 채우기 후에 기본 테이블의 변경 내용을 추적하는 테이블을 유지 관리하기 때문에 변경 내용 추적을 사용할 경우 약간의 오버헤드가 발생합니다. 변경 내용 추적을 사용하면 SQL Server에서 업데이트, 삭제 또는 삽입에 의해 수정된 기본 테이블 또는 인덱싱된 뷰의 행 레코드를 유지 관리합니다. WRITETEXT 및 UPDATETEXT를 통한 데이터 변경 내용은 전체 텍스트 인덱스에 반영되지 않고 변경 내용 추적 시 선택되지도 않습니다.

[!참고]

timestamp 열이 포함된 테이블에 대해서는 증분 채우기를 사용할 수 있습니다.

인덱스를 만드는 동안 변경 내용 추적을 설정하면 SQL Server에서 새 전체 텍스트를 만드는 즉시 완전히 채웁니다. 그 이후에는 변경 내용이 추적되고 전체 텍스트 인덱스로 전파됩니다. 변경 내용 추적에는 두 가지 유형, 자동(CHANGE_TRACKING AUTO 옵션)과 수동(CHANGE_TRACKING MANUAL 옵션)이 있습니다. 자동 변경 내용 추적이 기본 동작입니다.

변경 내용 추적의 유형에 따라 전체 텍스트 인덱스가 채워지는 방법이 다음과 같이 결정됩니다.

  • 자동 채우기

    기본적으로 또는 CHANGE_TRACKING AUTO를 지정한 경우 전체 텍스트 엔진은 전체 텍스트 인덱스에 대해 자동 채우기를 사용합니다. 초기 전체 채우기가 완료된 후 기본 테이블의 데이터가 수정되면 변경 내용이 추적되고 추적된 변경 내용이 자동으로 전파됩니다. 그러나 전체 텍스트 인덱스가 백그라운드에서 업데이트되기 때문에 전파된 변경 내용은 인덱스에 즉시 반영되지 않을 수도 있습니다.

    자동 채우기를 사용하는 변경 내용 추적을 설정하려면

    자세한 내용은 이 항목의 뒷부분에 나오는 예 "5. 자동 변경 내용 추적을 사용하도록 전체 텍스트 인덱스 변경"을 참조하십시오.

  • 수동 채우기

    CHANGE_TRACKING MANUAL을 지정한 경우 전체 텍스트 엔진은 전체 텍스트 인덱스에 대해 수동 채우기를 사용합니다. 초기 전체 채우기가 완료된 후 기본 테이블의 데이터가 수정되면 변경 내용이 추적됩니다. 그러나 추적된 변경 내용은 ALTER FULLTEXT INDEX … START UPDATE POPULATION 문을 실행할 때까지 전체 텍스트 인덱스로 전파되지 않습니다. SQL Server 에이전트를 사용하여 이 Transact-SQL 문을 주기적으로 호출할 수 있습니다.

    수동 채우기가 있는 변경 내용 추적을 시작하려면

    자세한 내용은 이 항목의 뒷부분에 나오는 예 "3. 수동 변경 내용 추적이 있는 전체 텍스트 인덱스 만들기" 및 "4. 수동 채우기 실행"을 참조하십시오.

변경 내용 추적 없음으로 변경 내용 추적을 설정하려면

증분 타임스탬프 기반 채우기

증분 채우기는 전체 텍스트 인덱스를 수동으로 채우는 대체 메커니즘으로, CHANGE_TRACKING이 MANUAL 또는 OFF로 설정된 전체 텍스트 인덱스에 대해 실행할 수 있습니다. 전체 텍스트 인덱스에 대해 처음으로 실행하는 채우기가 증분 채우기이면 모든 행이 인덱싱되므로 그 결과가 전체 채우기의 경우와 같습니다. 증분 채우기를 사용하려면 인덱싱된 테이블에 timestamp 데이터 형식의 열이 있어야 합니다. timestamp 열이 없으면 증분 채우기를 수행할 수 없습니다. timestamp 열이 없는 테이블에 대해 증분 채우기를 요청하면 전체 채우기 작업이 수행됩니다. 또한 테이블의 전체 텍스트 인덱스에 영향을 주는 메타데이터가 마지막 채우기 후에 변경된 경우 증분 채우기 요청은 전체 채우기로 구현됩니다. 여기에는 열, 인덱스 또는 전체 텍스트 인덱스 정의의 변경으로 인한 메타데이터 변경 내용이 포함됩니다.

SQL Server에서는 timestamp 열을 사용하여 마지막 채우기 후에 변경된 행을 식별합니다. 그러면 증분 채우기는 마지막 채우기 후 또는 마지막 채우기를 진행 중인 동안 추가, 삭제 또는 수정된 행에 대해 전체 텍스트 인덱스를 업데이트합니다. 테이블에서 대량 삽입이 발생하는 경우 증분 채우기를 사용하는 것이 수동 채우기를 사용하는 것보다 효율적일 수 있습니다.

채우기 완료 시 전체 텍스트 엔진은 새 timestamp 값을 기록합니다. 이 값은 SQL Gatherer에서 발생한 가장 큰 timestamp 값입니다. 이 값은 후속 증분 채우기가 시작될 때 사용됩니다.

증분 채우기를 실행하려면 START INCREMENTAL POPULATION 절을 사용하여 ALTER FULLTEXT INDEX 문을 실행합니다.

증분 채우기 작업을 예약하려면

[!참고]

이 섹션의 예에서는 AdventureWorks 예제 데이터베이스의 Production.Document 또는 HumanResources.JobCandidate 테이블을 사용합니다. 이러한 테이블에 대한 자세한 내용은 Document 테이블 및 JobCandidate 테이블(AdventureWorks)을 참조하십시오.

1. 전체 채우기를 실행하지 않고 전체 텍스트 인덱스 만들기

다음 예에서는 AdventureWorks 예제 데이터베이스의 Production.Document 테이블에서 전체 텍스트 인덱스를 만듭니다. 이 예에서는 WITH CHANGE_TRACKING OFF, NO POPULATION을 사용하여 초기 전체 채우기를 지연시킵니다.

CREATE UNIQUE INDEX ui_ukDoc ON Production.Document(DocumentID);
CREATE FULLTEXT CATALOG AW_Production_FTCat;
CREATE FULLTEXT INDEX ON Production.Document
(
    Document                         --Full-text index column name 
        TYPE COLUMN FileExtension    --Name of column that contains file type information
        Language 1033                 --1033 is LCID for the English language
)
    KEY INDEX ui_ukDoc
    ON AW_Production_FTCat
    WITH CHANGE_TRACKING OFF, NO POPULATION;
GO

2. 테이블에 대해 전체 채우기 실행

다음 예에서는 AdventureWorks 예제 데이터베이스의 Production.Document 테이블에 대해 전체 채우기를 실행합니다.

ALTER FULLTEXT INDEX ON Production.Document
   START FULL POPULATION;

3. 수동 변경 내용 추적이 있는 전체 텍스트 인덱스 만들기

다음 예에서는 AdventureWorks 예제 데이터베이스의 HumanResources.JobCandidate 테이블에 대해 수동 채우기가 있는 변경 내용 추적을 사용하는 전체 텍스트 인덱스를 만듭니다.

USE AdventureWorks;
GO
CREATE UNIQUE INDEX ui_ukJobCand ON HumanResources.JobCandidate(JobCandidateID);
CREATE FULLTEXT CATALOG ft AS DEFAULT;
CREATE FULLTEXT INDEX ON HumanResources.JobCandidate(Resume) 
   KEY INDEX ui_ukJobCand 
   WITH CHANGE_TRACKING=MANUAL;
GO

4. 수동 채우기 실행

다음 예에서는 AdventureWorks 예제 데이터베이스의 HumanResources.JobCandidate 테이블에서 변경 내용 추적이 설정된 전체 텍스트 인덱스에 대해 수동 채우기를 실행합니다.

USE AdventureWorks;
GO
ALTER FULLTEXT INDEX ON HumanResources.JobCandidate START UPDATE POPULATION;
GO

5. 자동 변경 내용 추적을 사용하도록 전체 텍스트 인덱스 변경

다음 예에서는 자동 채우기가 있는 변경 내용 추적을 사용하도록 AdventureWorks 예제 데이터베이스의 HumanResources.JobCandidate 테이블에 대한 전체 텍스트 인덱스를 변경합니다.

USE AdventureWorks;
GO
ALTER FULLTEXT INDEX ON HumanResources.JobCandidate SET CHANGE_TRACKING AUTO;
GO