DBCC SHRINKFILE(Transact-SQL)

업데이트: 2006년 4월 14일

현재 데이터베이스에 대해 지정한 데이터 또는 로그 파일의 크기를 축소하거나 지정한 파일의 데이터를 같은 파일 그룹의 다른 파일로 이동하여 파일을 비우고 데이터베이스에서 제거할 수 있도록 합니다. 파일을 만들 때 지정한 크기보다 작게 파일을 축소할 수 있습니다. 이 작업은 최소 파일 크기를 새 값으로 다시 설정합니다.

항목 링크 아이콘Transact-SQL 구문 표기 규칙

구문

DBCC SHRINKFILE 
(
    { file_name | file_id } 
    { [ , EMPTYFILE ] 
    | [ [ , target_size ] [ , { NOTRUNCATE | TRUNCATEONLY } ] ]
    }
)
[ WITH NO_INFOMSGS ]

인수

  • file_name
    축소할 파일의 논리적 이름입니다.
  • file_id
    축소할 파일의 ID 번호입니다. 파일 ID를 가져오려면 FILE_IDEX 시스템 함수를 사용하거나 현재 데이터베이스의 sys.database_files 카탈로그 뷰를 쿼리합니다.
  • target_size
    정수로 표시된 파일 크기(MB)입니다. 이 값을 지정하지 않으면 DBCC SHRINKFILE은 파일 크기를 기본 파일 크기로 줄입니다. 기본 크기는 파일을 만들 때 지정한 크기나 ALTER DATABASE를 사용하여 설정한 마지막 크기입니다.

    target_size를 지정하면 DBCC SHRINKFILE은 지정한 크기로 파일을 축소합니다. 파일의 해제될 부분에서 사용된 페이지는 보유된 부분의 사용 가능한 공간에 재배치됩니다. 예를 들어 10MB의 데이터 파일이 있을 경우 target_size를 8로 지정하여 DBCC SHRINKFILE 작업을 실행하면 파일의 마지막 2MB에서 사용된 모든 페이지는 파일의 처음 8MB에서 할당되지 않은 페이지에 다시 할당됩니다. DBCC SHRINKFILE은 파일에 데이터를 저장하는 데 필요한 크기 이하로 파일을 축소하지 않습니다. 예를 들어 10MB 데이터 파일에서 7MB가 사용된 경우 target_size가 6인 DBCC SHRINKFILE 문은 파일을 6MB가 아니라 7MB까지만 축소합니다.

  • EMPTYFILE
    지정한 파일의 모든 데이터를 동일한 파일 그룹의 다른 파일로 마이그레이션합니다. 데이터베이스 엔진에서 더 이상 빈 파일에 데이터를 저장할 수 없으므로 ALTER DATABASE 문을 사용하여 파일을 제거할 수 있습니다.
  • NOTRUNCATE
    target_percent를 지정하거나 지정하지 않고 데이터 파일의 끝에 있는 할당된 페이지를 파일 앞의 할당되지 않은 페이지로 이동합니다. 파일 끝에 남은 여유 공간을 운영 체제에 반환하지 않으므로 파일의 물리적 크기는 변경되지 않습니다. 그러므로 NOTRUNCATE를 지정하면 파일이 축소되지 않는 것처럼 보입니다.

    NOTRUNCATE는 데이터 파일에만 적용되며 로그 파일에는 영향을 주지 않습니다.

  • TRUNCATEONLY
    파일 끝에 남은 모든 여유 공간을 운영 체제로 확보하지만 파일 내에서 페이지를 이동하지 않습니다. 데이터 파일은 마지막으로 할당된 익스텐트까지만 축소됩니다.

    TRUNCATEONLY와 함께 지정하면 target_size는 무시됩니다.

    TRUNCATEONLY는 데이터 파일에만 적용됩니다.

  • WITH NO_INFOMSGS
    모든 정보 메시지를 표시하지 않습니다.

결과 집합

다음 표에서는 결과 집합의 열을 설명합니다.

열 이름 설명

DbId

데이터베이스 엔진에서 축소하려고 시도한 파일의 데이터베이스 ID 번호입니다.

FileId

데이터베이스 엔진에서 축소하려고 시도한 파일의 파일 ID 번호입니다.

CurrentSize

현재 파일이 차지하고 있는 8KB 페이지의 수입니다.

MinimumSize

파일이 최소한으로 차지할 수 있는 8KB 페이지의 수입니다. 이 값은 파일의 최소 크기나 원래 만들어졌을 때의 크기와 일치합니다.

UsedPages

현재 파일에서 사용되는 8KB 페이지의 수입니다.

EstimatedPages

데이터베이스 엔진에서 예상하는 파일 축소 가능 크기에 해당하는 8KB 페이지의 수입니다.

주의

DBCC SHRINKFILE은 현재 데이터베이스의 파일에만 적용됩니다. 현재 데이터베이스를 변경하는 방법은 USE(Transact-SQL)를 참조하십시오.

DBCC SHRINKFILE 작업은 진행 도중에 언제든지 중지될 수 있으며 완료된 작업은 모두 그대로 보존됩니다.

[!참고] SQL Server 2005에서는 DBCC SHRINKFILE 작업이 실패하면 오류가 발생합니다. 이전 버전의 SQL Server에서는 이 작업이 실패해도 오류가 발생하지 않습니다.

축소할 데이터베이스는 단일 사용자 모드가 아니어도 됩니다. 즉, 다른 사용자가 데이터베이스에서 작업 중이라도 파일을 축소할 수 있습니다. 시스템 데이터베이스를 축소하기 위해 SQL Server 2005 인스턴스를 단일 사용자 모드에서 실행하지 않아도 됩니다.

로그 파일 축소

로그 파일의 경우 SQL Server 2005 데이터베이스 엔진에서는 target_size를 사용하여 전체 로그의 대상 크기를 계산합니다. 따라서 target_size는 축소 작업 후 로그에 남겨질 여유 공간의 크기입니다. 그런 다음 전체 로그의 대상 크기가 각 로그 파일의 대상 크기로 변환됩니다. DBCC SHRINKFILE은 즉시 각 물리적 로그 파일을 대상 크기로 축소하려고 시도합니다. 그러나 가상 로그에 대상 크기보다 큰 논리 로그 부분이 있는 경우 데이터베이스 엔진은 가능한 한 많은 공간을 해제하고 정보용 메시지를 표시합니다. 이 메시지는 파일 끝의 가상 로그에서 논리 로그를 이동하기 위해 수행해야 하는 작업을 알려 줍니다. 작업이 수행되고 나면 DBCC SHRINKFILE을 사용하여 나머지 공간을 확보할 수 있습니다. 자세한 내용은 트랜잭션 로그 축소를 참조하십시오.

로그 파일은 가상 로그 파일 크기만큼만 축소할 수 있으므로 사용 중이 아닌 로그 파일이라도 가상 로그 파일의 크기보다 작게 축소할 수는 없습니다. 로그 파일이 생성되거나 확장될 때 데이터베이스 엔진에서 동적으로 가상 로그 파일의 크기가 선택됩니다. 가상 로그 파일에 대한 자세한 내용은 트랜잭션 로그 물리 아키텍처를 참조하십시오.

최상의 방법

파일을 축소할 때는 다음 정보를 고려하십시오.

  • 축소 작업은 테이블 잘라내기 또는 테이블 삭제 작업과 같이 사용되지 않는 공간이 많이 생기는 작업이 수행된 후에 실행하는 것이 가장 효과적입니다.
  • 대부분의 데이터베이스에는 정기적인 일상 작업에 사용 가능한 일정 여유 공간이 필요합니다. 데이터베이스를 반복해서 축소했지만 데이터베이스 크기가 다시 늘어나는 경우 일반 작업을 위해 축소된 공간이 필요한 것입니다. 이러한 경우 데이터베이스를 반복해서 축소하는 것은 불필요한 작업입니다.
  • 축소 작업은 데이터베이스 인덱스의 조각화 상태를 보존하지 않으며 일반적으로 조각화 정도를 어느 정도까지 늘리기도 합니다. 이것은 데이터베이스를 반복해서 축소하지 않아야 하는 또 다른 이유입니다.

문제 해결

이 섹션에서는 DBCC SHRINKFILE 명령을 실행할 때 발생할 수 있는 문제를 진단하고 해결하는 방법에 대해 설명합니다.

파일이 축소되지 않음

축소 작업이 오류 없이 실행되지만 파일 크기가 변경되지 않은 것처럼 보이면 다음 작업 중 하나를 수행하여 파일에 제거할 여유 공간이 있는지 확인합니다.

  • 다음 쿼리를 실행합니다.

    SELECT name ,size/128.0 - CAST(FILEPROPERTY(name, 'SpaceUsed') AS int)/128.0 AS AvailableSpaceInMB
    FROM sys.database_files;
    
  • DBCC SQLPERF 명령을 실행하여 트랜잭션 로그에서 사용된 공간을 반환합니다.

사용 가능한 여유 공간이 충분하지 않으면 축소 작업에서 파일 크기를 더 이상 줄일 수 없습니다.

일반적으로 축소되지 않는 것처럼 보이는 파일은 로그 파일입니다. 이는 로그 파일이 잘리지 않았기 때문입니다. 데이터베이스 복구 모델을 SIMPLE로 설정하거나 로그를 백업한 다음 DBCC SHRINKFILE 작업을 다시 실행하여 로그를 자를 수 있습니다. 자세한 내용은 트랜잭션 로그 잘림트랜잭션 로그 축소를 참조하십시오.

축소 작업이 차단됨

행 버전 관리 기반 격리 수준에서 실행 중인 트랜잭션에 의해 축소 작업이 차단될 수 있습니다. 예를 들어 DBCC SHRINK DATABASE 작업을 실행할 때 행 버전 관리 기반 격리 수준에서 실행 중인 대규모 삭제 작업이 진행되고 있으면 축소 작업은 파일을 축소하기 전에 삭제 작업이 완료될 때까지 기다립니다. 이러한 경우 DBCC SHRINKFILE과 DBCC SHRINKDATABASE 작업은 처음 한 시간 동안에는 5분마다 그리고 그 다음부터는 한 시간마다 SQL Server 오류 로그에 정보 메시지(SHRINKDATABASE의 경우 5202 그리고 SHRINKFILE의 경우 5203)를 출력합니다. 예를 들어 오류 로그에 다음과 같은 오류 메시지가 있습니다.

DBCC SHRINKFILE for file ID 1 is waiting for the snapshot 
transaction with timestamp 15 and other snapshot transactions linked to 
timestamp 15 or with timestamps older than 109 to finish.

이는 축소 작업이 완료된 마지막 트랜잭션인 109보다 오래된 타임스탬프가 있는 스냅숏 트랜잭션에 의해 축소 작업이 차단됨을 의미합니다. 또한 sys.dm_tran_active_snapshot_database_transactions 동적 관리 뷰에서 transaction_sequence_num 또는 first_snapshot_sequence_num 열의 값이 15임을 나타냅니다. 뷰의 transaction_sequence_num 또는 first_snapshot_sequence_num 열에 포함된 숫자가 축소 작업이 완료된 마지막 트랜잭션(109)보다 작으면 축소 작업은 해당 트랜잭션이 완료될 때까지 대기합니다.

문제를 해결하려면 다음 작업 중 하나를 수행하십시오.

  • 축소 작업을 차단하는 트랜잭션을 종료합니다.
  • 축소 작업을 종료합니다. 축소 작업을 종료해도 완료된 작업은 모두 보존됩니다.
  • 아무 작업도 하지 않고 차단하는 트랜잭션이 완료될 때까지 축소 작업이 대기할 수 있게 합니다.

SQL Server 오류 로그에 대한 자세한 내용은 SQL Server 오류 로그 보기를 참조하십시오.

사용 권한

sysadmin 고정 서버 역할의 멤버 또는 db_owner 고정 데이터베이스 역할의 멤버여야 합니다.

1. 데이터 파일을 지정한 대상 크기로 축소

다음 예에서는 UserDB 사용자 데이터베이스에 있는 DataFile1이라는 데이터 파일의 크기를 7MB로 축소합니다.

USE UserDB;
GO
DBCC SHRINKFILE (DataFile1, 7);
GO

2. 로그 파일을 지정한 대상 크기로 축소

다음 예에서는 AdventureWorks 데이터베이스에 있는 로그 파일을 1MB로 축소합니다. DBCC SHRINKFILE 명령이 파일을 축소할 수 있도록 먼저 데이터베이스 복구 모델을 SIMPLE로 설정하여 파일을 자릅니다.

USE AdventureWorks;
GO
-- Truncate the log by changing the database recovery model to SIMPLE.
ALTER DATABASE AdventureWorks
SET RECOVERY SIMPLE;
GO
-- Shrink the truncated log file to 1 MB.
DBCC SHRINKFILE (AdventureWorks_Log, 1);
GO
-- Reset the database recovery model.
ALTER DATABASE AdventureWorks
SET RECOVERY FULL;
GO

3. 데이터 파일 자름

다음 예에서는 AdventureWorks 데이터베이스의 주 데이터 파일을 자릅니다. sys.database_files 카탈로그 뷰를 쿼리하여 데이터 파일의 file_id를 가져옵니다.

USE AdventureWorks;
GO
SELECT file_id, name
FROM sys.database_files;
GO
DBCC SHRINKFILE (1, TRUNCATEONLY);

4. 파일 비우기

다음 예에서는 데이터베이스에서 제거할 수 있도록 파일을 비우는 프로시저를 보여 줍니다. 이 예의 목적을 위해 데이터 파일이 먼저 생성되고 파일에 데이터가 있다고 가정합니다.

USE AdventureWorks;
GO
-- Create a data file and assume it contains data.
ALTER DATABASE AdventureWorks 
ADD FILE (
    NAME = Test1data,
    FILENAME = 'C:\t1data.ndf',
    SIZE = 5MB
    );
GO
-- Empty the data file.
DBCC SHRINKFILE (Test1data, EMPTYFILE);
GO
-- Remove the data file from the database.
ALTER DATABASE AdventureWorks
REMOVE FILE Test1data;
GO

참고 항목

참조

ALTER DATABASE(Transact-SQL)
DBCC(Transact-SQL)
DBCC SHRINKDATABASE(Transact-SQL)
FILE_ID(Transact-SQL)
sys.database_files(Transact-SQL)

관련 자료

물리적 데이터베이스 파일 및 파일 그룹
방법: 파일 축소(SQL Server Management Studio)
페이지 및 익스텐트

도움말 및 정보

SQL Server 2005 지원 받기

변경 내역

릴리스 내역

2006년 4월 14일

새로운 내용
  • "파일이 축소되지 않음" 섹션을 추가했습니다.
  • "축소 작업이 차단됨" 섹션에 해결 작업을 추가했습니다.
  • 예 2, 3, 4를 추가했습니다.
업데이트된 내용
  • TRUNCATEONLY 및 NOTRUNCATE 정의에 대한 자세한 설명을 추가했습니다.