다음을 통해 공유


Full-Text 인덱스 관리

Full-Text 인덱스의 속성 보기 및 변경

Management Studio에서 전체 텍스트 인덱스의 속성을 보거나 변경하려면

  1. 개체 탐색기에서 서버를 확장합니다.

  2. 데이터베이스를 확장한 다음 전체 텍스트 인덱스가 포함된 데이터베이스를 확장합니다.

  3. 테이블을 확장합니다.

  4. 전체 텍스트 인덱스가 정의된 테이블을 마우스 오른쪽 단추로 클릭하고 전체 텍스트 인덱스를 선택한 다음 전체 텍스트 인덱스 상황에 맞는 메뉴에서 속성을 클릭합니다. 그러면 전체 텍스트 인덱스 속성 대화 상자가 열립니다.

  5. 페이지 선택 창에서 다음 페이지 중 원하는 페이지를 선택할 수 있습니다.

    페이지 설명
    일반 전체 텍스트 인덱스의 기본 속성을 표시합니다. 여기에는 몇 가지 수정 가능한 속성과 데이터베이스 이름, 테이블 이름 및 전체 텍스트 키 열의 이름과 같은 변경 불가능한 여러 속성이 포함됩니다. 수정할 가능한 속성은 다음과 같습니다.

    전체 텍스트 인덱스 중지 목록

    전체 텍스트 인덱싱 사용

    변경 내용 추적

    검색 속성 목록



    자세한 내용은 Full-Text 인덱스 속성(일반 페이지)을 참조하세요.
    전체 텍스트 인덱싱에 사용할 수 있는 테이블 열을 표시합니다. 선택한 열 또는 열들이 전체 텍스트로 인덱싱되어 있습니다. 이때 전체 텍스트 인덱스에 포함하려는 만큼 사용 가능한 열을 선택할 수 있습니다. 자세한 내용은 Full-Text 인덱스 속성(열 페이지)을 참조하세요.
    일정 이 페이지를 사용하여 전체 텍스트 인덱스 채우기에 대한 증분 테이블 채우기를 시작하는 SQL Server 에이전트 작업에 대한 일정을 만들거나 관리할 수 있습니다. 자세한 내용은 전체 텍스트 인덱스 채우기를 참조하세요.

    **중요하다**Full-Text 인덱스 속성 대화 상자를 종료하면 새로 만든 일정이 SQL Server 에이전트 작업( database_name 증분 테이블 채우기 시작)과 연결됩니다.table_name).
  6. 확인을 클릭합니다. 변경 내용을 저장하고 전체 텍스트 인덱스 속성 대화 상자를 종료합니다.

인덱싱된 테이블 및 열의 속성 보기

다양한 전체 텍스트 인덱싱 속성의 값을 얻기 위해 OBJECTPROPERTYEX와 같은 여러 Transact-SQL 함수를 사용할 수 있습니다. 이 정보는 전체 텍스트 검색을 관리하고 문제를 해결하는 데 유용합니다.

다음 표에서는 인덱싱된 테이블 및 열과 관련된 전체 텍스트 속성과 관련 Transact-SQL 함수를 나열합니다.

재산 설명 기능
FullTextTypeColumn 열의 문서 종류 정보를 보유한 테이블의 유형 열입니다. COLUMNPROPERTY
IsFulltextIndexed 열에 대한 전체 텍스트 인덱싱 설정 여부를 나타냅니다. 열속성 (COLUMNPROPERTY)
IsFulltextKey 인덱스가 테이블의 전체 텍스트 키인지 여부입니다. INDEXPROPERTY
테이블전체텍스트백그라운드업데이트인덱스온 테이블에 전체 텍스트 백그라운드 업데이트 인덱싱이 있는지 여부입니다. OBJECTPROPERTYEX
TableFulltextCatalogId 테이블에 대한 전체 텍스트 인덱스 데이터가 상주하는 전체 텍스트 카탈로그 ID입니다. OBJECTPROPERTYEX
TableFulltextChangeTrackingOn 테이블의 전체 텍스트 변경 내용 추적이 활성화되어 있는지 여부입니다. OBJECTPROPERTYEX
TableFulltextDocsProcessed 전체 텍스트 인덱싱이 시작된 이후에 처리된 행의 수입니다. 오브젝트 속성 확장 (OBJECTPROPERTYEX)
테이블전체문자실패횟수 검색에서 인덱싱되지 않은 행 Full-Text의 수입니다. OBJECTPROPERTYEX
표 전체 텍스트 항목 수 성공적으로 전체 텍스트 인덱싱된 행의 수입니다. OBJECTPROPERTYEX
TableFulltextKeyColumn 전체 텍스트 고유 키 열의 열 ID입니다. OBJECTPROPERTYEX
TableFullTextMergeStatus 테이블에 현재 병합 중인 전체 텍스트 인덱스가 있는지를 나타냅니다. OBJECTPROPERTYEX
테이블전체텍스트대기중인변경사항 처리할 보류 중인 변경 내용 추적 항목의 수입니다. OBJECTPROPERTYEX
TableFulltextPopulateStatus 전체 텍스트 테이블의 현황입니다. OBJECTPROPERTYEX
TableHasActiveFulltextIndex 테이블에 활성 전체 텍스트 인덱스가 있는지 여부입니다. OBJECTPROPERTYEX (객체 속성 확장)

Full-Text 키 열에 대한 정보 가져오기

일반적으로 CONTAINSTABLE 또는 FREETEXTTABLE 행 집합 반환 함수의 결과는 기본 테이블과 조인되어야 합니다. 이러한 경우 고유한 키 열 이름을 알아야 합니다. 지정된 고유 인덱스가 전체 텍스트 키로 사용되는지 여부를 확인할 수 있으며 전체 텍스트 키 열의 식별자를 가져올 수 있습니다.

지정된 고유 인덱스가 전체 텍스트 키 열로 사용되는지 여부를 확인하려면

  1. SELECT 문을 사용하여 INDEXPROPERTY 함수를 호출합니다. 함수 호출에서 OBJECT_ID 함수를 사용하여 테이블 이름(table_name)을 테이블 ID로 변환하고, 테이블의 고유 인덱스 이름을 지정하고, 다음과 같이 인덱스 속성을 지정 IsFulltextKey 합니다.

    SELECT INDEXPROPERTY( OBJECT_ID('table_name'), 'index_name',  'IsFulltextKey' );  
    

    이 문은 인덱스가 전체 텍스트 키 열의 고유성을 적용하는 데 사용되는 경우 1을 반환하고, 그렇지 않으면 0을 반환합니다.

예시

다음 예제에서는 다음과 같이 PK_Document_DocumentID 인덱스를 사용하여 전체 텍스트 키 열의 고유성을 적용하는지 여부를 확인합니다.

USE AdventureWorks  
GO  
SELECT INDEXPROPERTY ( OBJECT_ID('Production.Document'), 'PK_Document_DocumentID',  'IsFulltextKey' )  

다음은 PK_Document_DocumentID 인덱스가 전체 텍스트 키 열의 고유성을 적용하는 데 사용되는 경우 1을 반환하는 예제입니다. 그렇지 않은 경우 0 또는 null을 반환합니다. NULL은 잘못된 인덱스 이름을 사용 중이거나, 인덱스 이름이 테이블에 해당하지 않거나, 테이블이 존재하지 않는 등을 의미합니다.

전체 텍스트 키 열의 식별자를 찾으려면

  1. 각 전체 텍스트 사용 테이블에는 테이블에 고유한 행을 적용하는 데 사용되는 열( unique**key 열)이 있습니다. OBJECTPROPERTYEX 함수에서 가져온 속성에는 TableFulltextKeyColumn 고유 키 열의 열 ID가 포함됩니다.

    이 식별자를 가져오려면 SELECT 문을 사용하여 OBJECTPROPERTYEX 함수를 호출하면 됩니다. OBJECT_ID 함수를 사용하여 테이블 이름(table_name)을 테이블 ID로 변환하고 다음과 같이 속성을 지정 TableFulltextKeyColumn 합니다.

    SELECT OBJECTPROPERTYEX(OBJECT_ID( 'table_name'), 'TableFulltextKeyColumn' ) AS 'Column Identifier';  
    

예제

다음 예제에서는 전체 텍스트 키 열 또는 NULL의 식별자를 반환합니다. NULL은 잘못된 인덱스 이름을 사용 중이거나, 인덱스 이름이 테이블에 해당하지 않거나, 테이블이 존재하지 않는 등을 의미합니다.

USE AdventureWorks;  
GO  
SELECT OBJECTPROPERTYEX(OBJECT_ID('Production.Document'), 'TableFulltextKeyColumn');  
GO  

다음 예제에서는 고유 키 열의 식별자를 사용하여 열의 이름을 가져오는 방법을 보여 있습니다.

USE AdventureWorks;  
GO  
DECLARE @key_column sysname  
SET @key_column = Col_Name(Object_Id('Production.Document'),  
ObjectProperty(Object_id('Production.Document'),  
'TableFulltextKeyColumn')   
)  
SELECT @key_column AS 'Unique Key Column';  
GO  

다음은 Document 테이블 DocumentID의 고유 키 열 이름을 포함하는 단일 행을 표시하는 결과 Unique Key Column집합 열을 반환하는 예제입니다. 이 쿼리에 잘못된 인덱스 이름이 포함된 경우 인덱스 이름이 테이블에 해당하지 않고 테이블이 없으므로 NULL을 반환합니다.

Full-Text 인덱싱을 위해 테이블 비활성화 또는 재활성화

SQL Server에서 사용자가 만든 모든 데이터베이스는 기본적으로 전체 텍스트가 활성화되어 있습니다. 또한 전체 텍스트 인덱스가 만들어지고 열이 인덱스로 추가되는 즉시 개별 테이블이 자동으로 전체 텍스트 인덱싱을 사용하도록 설정됩니다. 마지막 열이 전체 텍스트 인덱스에서 삭제되면 전체 텍스트 인덱싱에 대해 테이블이 자동으로 비활성화됩니다.

전체 텍스트 인덱스가 있는 테이블에서 SQL Server Management Studio를 사용하여 테이블에서의 전체 텍스트 인덱싱을 수동으로 해제하거나 다시 설정할 수 있습니다.

전체 텍스트 인덱싱에 테이블을 사용하도록 설정하려면

  1. 서버 그룹을 확장하고, 데이터베이스를 확장하고, 전체 텍스트 인덱싱을 사용하도록 설정할 테이블이 포함된 데이터베이스를 확장합니다.

  2. 테이블을 확장하고 전체 텍스트 인덱싱을 사용하지 않도록 설정하거나 다시 사용하도록 설정할 테이블을 마우스 오른쪽 단추로 클릭합니다.

  3. Full-Text 인덱스를 선택한 다음, Full-Text 인덱스 사용 안 함 또는 Full-Text 인덱스 사용을 클릭합니다.

테이블에서 Full-Text 인덱스 제거

테이블에서 전체 텍스트 인덱스 제거

  1. 개체 탐색기 삭제할 전체 텍스트 인덱스가 있는 테이블을 마우스 오른쪽 단추로 클릭합니다.

  2. 전체 텍스트 인덱스 삭제를 선택합니다.

  3. 메시지가 표시되면 확인을 클릭하여 전체 텍스트 인덱스 삭제를 확인합니다.