이 항목에서는 SQL Server Management Studio 또는 Transact-SQL을 사용하여 SQL Server 2014에서 데이터 또는 로그 파일을 축소하는 방법을 설명합니다.
데이터 파일을 축소하면 파일 끝에 있는 데이터 페이지를 파일 앞부분의 비어 있는 공간으로 이동하여 공간을 복구할 수 있습니다. 파일 끝에 충분한 여유 공간이 만들어지면 파일 끝에 있는 데이터 페이지의 할당을 취소하고 파일 시스템으로 반환할 수 있습니다.
이 항목에서
시작하기 전 주의 사항:
데이터 또는 로그 파일을 축소하려면:
시작하기 전에
한계 및 제한사항
- 기본 데이터 파일은 모델 데이터베이스의 주 파일 크기보다 작게 만들 수 없습니다.
권장 사항
- 파일 축소를 위해 이동되는 데이터는 파일 내의 모든 사용 가능한 위치로 분산될 수 있습니다. 이로 인해 인덱스 조각이 발생하고 인덱스 범위를 검색하는 쿼리의 성능이 저하될 수 있습니다. 조각을 제거하려면 축소한 후 파일의 인덱스를 다시 빌드하는 것이 좋습니다.
안전
권한
sysadmin 고정 서버 역할의 멤버 또는 db_owner 고정 데이터베이스 역할의 멤버여야 합니다.
SQL Server Management Studio 사용
데이터 또는 로그 파일을 축소하려면
개체 탐색기에서 SQL Server 데이터베이스 엔진의 인스턴스에 연결한 다음 해당 인스턴스를 확장합니다.
데이터베이스를 확장한 다음 축소할 데이터베이스를 마우스 오른쪽 단추로 클릭합니다.
작업을 선택하고 축소를 선택한 다음 파일을 클릭합니다.
데이터베이스
선택한 데이터베이스의 이름을 표시합니다.파일 형식
파일의 파일 형식을 선택합니다. 데이터 와 로그 파일 중에 선택할 수 있습니다. 기본 선택은 데이터입니다. 다른 파일 그룹 형식을 선택하면 변경 내용에 따라 다른 필드의 선택 내용도 변경됩니다.파일 그룹
위에서 선택한 파일 형식과 관련된 파일 그룹 목록에서 파일 그룹을 선택합니다. 다른 파일 그룹을 선택하면 변경 내용에 따라 다른 필드의 선택 내용도 변경됩니다.파일 이름
선택한 파일 그룹 및 파일 형식의 사용 가능한 파일 목록에서 파일을 선택합니다.위치
현재 선택한 파일의 전체 경로를 표시합니다. 경로를 편집할 수 없지만 클립보드에 복사할 수 있습니다.현재 할당된 공간
데이터 파일의 경우 현재 할당된 공간을 표시합니다. 로그 파일의 경우 DBCC SQLPERF(LOGSPACE)의 출력에서 계산된 현재 할당된 공간을 표시합니다.사용 가능한 공간
현재 데이터 파일에 사용할 수 있는 여유 공간은 DBCC SHOWFILESTATS(fileid)의 출력에서 계산됩니다. 로그 파일의 경우, DBCC SQLPERF(LOGSPACE)의 출력 결과에서 계산된 현재 사용 가능한 공간을 표시합니다.사용하지 않은 공간 해제
파일에서 사용되지 않는 공간을 운영 체제에 릴리스하고 파일을 마지막으로 할당된 범위로 축소하여 데이터를 이동하지 않고 파일 크기를 줄입니다. 행을 할당되지 않은 페이지로 재배치하려고 시도하지 않습니다.사용하지 않은 공간을 해제하기 전에 페이지 다시 구성
대상 파일 크기를 지정하는 DBCC SHRINKFILE 실행과 동일합니다. 이 옵션을 선택하면 사용자가 파일을 다음으로 축소 상자에서 대상 파일 크기를 지정해야 합니다.파일 크기를 다음으로 줄이기
축소 작업의 대상 파일 크기를 지정합니다. 크기는 현재 할당된 공간보다 작거나 파일에 할당된 총 익스텐트보다 작을 수 없습니다. 최소값 또는 최대값을 초과하는 값을 입력하면 포커스가 변경되거나 도구 모음의 단추를 클릭하면 최소 또는 최대값으로 되돌아갑니다.동일한 파일 그룹의 다른 파일로 데이터를 마이그레이션하여 파일 비우기
지정된 파일에서 모든 데이터를 마이그레이션합니다. 이 옵션을 사용하면 ALTER DATABASE 문을 통해 파일을 삭제할 수 있습니다. 이 옵션은 EMPTYFILE 옵션을 사용하여 DBCC SHRINKFILE을 실행하는 것과 같습니다.파일 형식 및 파일 이름을 선택합니다.
필요에 따라 사용하지 않은 공간 해제 확인란을 선택합니다.
이 옵션을 선택하면 파일의 사용하지 않은 공간이 운영 체제로 해제되고 파일이 마지막으로 할당된 범위로 축소됩니다. 이를 통해 데이터를 이동하지 않고 파일 크기를 줄일 수 있습니다.
필요에 따라 사용하지 않은 공간을 해제하기 전에 파일 다시 구성 확인란을 선택합니다. 이 옵션을 선택하면 파일을 지정한 크기로 축소 값을 지정해야 합니다. 기본적으로 이 옵션은 선택 취소되어 있습니다.
이 옵션을 선택할 경우 파일의 사용하지 않은 공간이 시스템에 반환되고, 행을 할당되지 않은 페이지로 재배치하려고 시도합니다.
선택적으로 데이터베이스를 축소한 후 데이터베이스 파일에 남겨둘 여유 공간의 최대 비율을 입력합니다. 허용되는 값은 0에서 99 사이입니다. 이 옵션은 사용하지 않은 공간을 해제하기 전에 파일 다시 구성 을 활성화한 경우에만 사용할 수 있습니다.
필요에 따라 동일한 파일 그룹의 다른 파일로 데이터를 마이그레이션하여 파일 비우기 확인란을 선택합니다.
이 옵션을 선택하면 지정한 파일의 모든 데이터를 파일 그룹의 다른 파일로 이동합니다. 그런 다음 빈 파일을 삭제할 수 있습니다. 이 옵션은 EMPTYFILE 옵션을 사용하여 DBCC SHRINKFILE을 실행하는 것과 동일합니다.
OK를 클릭합니다.
Transact-SQL 사용
데이터 또는 로그 파일을 축소하려면
데이터베이스 엔진에 연결합니다.
표준 도구 모음에서 새 쿼리를 클릭합니다.
다음 예를 복사하여 쿼리 창에 붙여 넣고 실행을 클릭합니다. 이 예제에서는 DBCC SHRINKFILE을 사용하여
DataFile1데이터베이스에 명명된UserDB데이터 파일의 크기를 7MB로 줄입니다.
USE UserDB;
GO
DBCC SHRINKFILE (DataFile1, 7);
GO
또한 참조하십시오
DBCC SHRINKDATABASE(Transact-SQL)
데이터베이스 축소
데이터베이스에서 데이터 또는 로그 파일 삭제
sys.databases(Transact-SQL)
sys.database_files(Transact-SQL)