다음을 통해 공유


통계 업데이트

적용 대상: SQL Server Azure SQL 데이터베이스 SQL Managed Instance Azure Synapse Analytics PDW(분석 플랫폼 시스템)

SQL Server 또는 SQL Server Management Studio 을 사용하여 Transact-SQL에서 테이블 또는 인덱싱된 뷰에 대한 쿼리 최적화 통계를 업데이트할 수 있습니다. 기본적으로 쿼리 최적화 프로그램은 이미 필요할 때 통계를 업데이트하여 쿼리 계획을 향상시킵니다. 하지만 경우에 따라 사용자가 UPDATE STATISTICS 또는 저장 프로시저 sp_updatestats를 사용하여 기본 업데이트 주기보다 더 자주 통계를 업데이트하여 쿼리 성능을 향상시킬 수 있습니다.

통계를 업데이트하면 쿼리가 최신 통계로 컴파일되지만 통계를 업데이트하면 쿼리가 다시 컴파일됩니다. 쿼리 계획 향상과 쿼리 재컴파일 소요 시간 간의 성능 균형을 유지해야 하므로 통계를 너무 자주 업데이트하지 않는 것이 좋습니다. 구체적인 성능 균형 유지의 정도는 애플리케이션에 따라 달라집니다. UPDATE STATISTICS는 통계를 작성하기 위해 tempdb를 사용하여 행 샘플을 정렬할 수 있습니다.

사용 권한

UPDATE STATISTICS를 사용하거나 SQL Server Management Studio를 통해 변경하는 경우 테이블 또는 뷰에 대한 ALTER 권한이 필요합니다. sp_updatestats를 사용할 경우 sysadmin 고정 서버 역할에 멤버 자격이 있거나 데이터베이스(dbo)의 소유권이 있어야 합니다.

SQL Server Management Studio 사용

통계 개체 업데이트

  1. 개체 탐색기에서 더하기 기호를 선택하여 통계를 업데이트할 데이터베이스를 확장합니다.

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

  3. 더하기 기호를 클릭하여 통계를 업데이트할 테이블을 확장합니다.

  4. 더하기 기호를 선택하여 통계 폴더를 확장합니다.

  5. 업데이트하려는 통계 개체를 마우스 오른쪽 단추로 클릭하고 속성을 선택합니다.

  6. 통계 속성 –statistics_name 대화 상자에서 이 열에 대한 통계 업데이트 확인란을 선택한 다음 확인을 선택합니다.

Transact-SQL 사용

특정 통계 개체 업데이트

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

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

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

    USE AdventureWorks2022;
    GO
    -- The following example updates the statistics for the AK_SalesOrderDetail_rowguid index of the SalesOrderDetail table.
    UPDATE STATISTICS Sales.SalesOrderDetail AK_SalesOrderDetail_rowguid;
    GO
    

테이블의 모든 통계 업데이트

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

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

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

    USE AdventureWorks2022;
    GO
    -- The following example updates the statistics for all indexes on the SalesOrderDetail table.
    UPDATE STATISTICS Sales.SalesOrderDetail;
    GO
    

자세한 내용은 UPDATE STATISTICS를 참조하세요.

데이터베이스의 모든 통계 업데이트

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

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

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

    USE AdventureWorks2022;
    GO
    -- The following example updates the statistics for all tables in the database.
    EXEC sp_updatestats;
    

자동 인덱스 및 통계 관리

Adaptive Index Defrag와 같은 솔루션을 사용하여 하나 이상의 데이터베이스에 대한 인덱스 조각 모음 및 통계 업데이트를 자동으로 관리합니다. 이 절차는 다른 매개 변수 사이에서 조각화 수준에 따라 인덱스를 다시 작성하거나 다시 구성할지 여부를 자동으로 선택하고 통계를 선형 임계값으로 업데이트합니다.