인덱스 옵션 설정

이 항목에서는 SQL Server Management Studio 또는 Transact-SQL을 사용하여 SQL Server 2012에서 인덱스 속성을 수정하는 방법에 대해 설명합니다.

항목 내용

  • 시작하기 전에:

    제한 사항

    보안

  • 인덱스 속성을 수정하려면:

    SQL Server Management Studio

    Transact-SQL

시작하기 전에

제한 사항

  • ALLOW_PAGE_LOCKS, ALLOW_ROW_LOCKS, IGNORE_DUP_KEY 및 STATISTICS_NORECOMPUTE 옵션은 ALTER INDEX 문에서 SET 절을 사용하면 즉시 인덱스에 적용됩니다.

  • PAD_INDEX, FILLFACTOR, SORT_IN_TEMPDB, IGNORE_DUP_KEY, STATISTICS_NORECOMPUTE, ONLINE, ALLOW_ROW_LOCKS, ALLOW_PAGE_LOCKS, MAXDOP 및 DROP_EXISTING(CREATE INDEX의 경우에만) 옵션은 ALTER INDEX REBUILD 또는 CREATE INDEX WITH DROP_EXISTING 중 하나를 사용하여 인덱스를 다시 작성할 때 설정할 수 있습니다.

보안

사용 권한

테이블이나 뷰에 대한 ALTER 권한이 필요합니다.

맨 위로 이동 링크와 함께 사용되는 화살표 아이콘[Top]

SQL Server Management Studio 사용

테이블 디자이너에서 인덱스 속성을 수정하려면

  1. 개체 탐색기에서 더하기 기호를 클릭하여 인덱스 속성을 수정할 테이블이 포함된 데이터베이스를 확장합니다.

  2. 더하기 기호를 클릭하여 테이블 폴더를 확장합니다.

  3. 인덱스 속성을 수정할 테이블을 마우스 오른쪽 단추로 클릭하고 디자인을 선택합니다.

  4. 테이블 디자이너 메뉴에서 인덱스/키를 클릭합니다.

  5. 수정할 인덱스를 선택합니다. 주 표에 속성이 표시됩니다.

  6. 속성의 설정을 변경하여 인덱스를 사용자 지정합니다.

  7. 닫기를 클릭합니다.

  8. 파일 메뉴에서 table_name 저장을 선택합니다.

개체 탐색기에서 인덱스 속성을 수정하려면

  1. 개체 탐색기에서 더하기 기호를 클릭하여 인덱스 속성을 수정할 테이블이 포함된 데이터베이스를 확장합니다.

  2. 더하기 기호를 클릭하여 테이블 폴더를 확장합니다.

  3. 더하기 기호를 클릭하여 인덱스 속성을 수정할 테이블을 확장합니다.

  4. 더하기 기호를 클릭하여 인덱스 폴더를 확장합니다.

  5. 속성을 수정할 인덱스를 마우스 오른쪽 단추로 클릭하고 속성을 선택합니다.

  6. 페이지 선택 아래에서 옵션을 선택합니다.

  7. 속성의 설정을 변경하여 인덱스를 사용자 지정합니다.

  8. 인덱스 열을 추가 또는 제거하거나 그 위치를 변경하려면 인덱스 속성 - index_name 대화 상자에서 일반 페이지를 선택합니다. 자세한 내용은 인덱스 속성 F1 도움말을 참조하십시오.

맨 위로 이동 링크와 함께 사용되는 화살표 아이콘[Top]

Transact-SQL 사용

테이블에 있는 모든 인덱스의 속성을 보려면

  1. 개체 탐색기에서 데이터베이스 엔진 인스턴스에 연결합니다.

  2. 표준 도구 모음에서 새 쿼리를 클릭합니다.

  3. 다음 예를 복사하여 쿼리 창에 붙여 넣고 실행을 클릭합니다.

    USE AdventureWorks2012;
    GO
    SELECT i.name AS index_name, 
        i.type_desc, 
        i.is_unique, 
        ds.type_desc AS filegroup_or_partition_scheme, 
        ds.name AS filegroup_or_partition_scheme_name, 
        i.ignore_dup_key, 
        i.is_primary_key, 
        i.is_unique_constraint, 
        i.fill_factor, 
        i.is_padded, 
        i.is_disabled, 
        i.allow_row_locks, 
        i.allow_page_locks, 
        i.has_filter, 
        i.filter_definition
    FROM sys.indexes AS i
       INNER JOIN sys.data_spaces AS ds ON i.data_space_id = ds.data_space_id
    WHERE is_hypothetical = 0 AND i.index_id <> 0 
       AND i.object_id = OBJECT_ID('HumanResources.Employee'); 
    GO
    

인덱스의 속성을 설정하려면

  1. 개체 탐색기에서 데이터베이스 엔진 인스턴스에 연결합니다.

  2. 표준 도구 모음에서 새 쿼리를 클릭합니다.

  3. 다음 예를 복사하여 쿼리 창에 붙여 넣고 실행을 클릭합니다.

    USE AdventureWorks2012;
    GO
    ALTER INDEX AK_SalesOrderHeader_SalesOrderNumber ON
        Sales.SalesOrderHeader
    SET (
        STATISTICS_NORECOMPUTE = ON,
        IGNORE_DUP_KEY = ON,
        ALLOW_PAGE_LOCKS = ON
        ) ;
    GO
    
    USE AdventureWorks2012;
    GO
    ALTER INDEX ALL ON Production.Product
    REBUILD WITH (FILLFACTOR = 80, SORT_IN_TEMPDB = ON,
                  STATISTICS_NORECOMPUTE = ON);
    GO
    

자세한 내용은 ALTER INDEX(Transact-SQL)를 참조하십시오.

맨 위로 이동 링크와 함께 사용되는 화살표 아이콘[Top]