sp_spaceused(Transact-SQL)
행의 수, 예약된 디스크 공간 및 현재 데이터베이스의 테이블, 인덱싱된 뷰 또는 SQL Server 2005 Service Broker 에서 사용하는 디스크 공간을 표시하거나, 전체 데이터베이스가 예약하여 사용하는 디스크 공간을 표시합니다.
구문
sp_spaceused [[ @objname = ] 'objname' ]
[,[ @updateusage = ] 'updateusage' ]
인수
[ @objname=] 'objname'
공간 사용 정보가 요청된 테이블, 인덱싱된 뷰 또는 큐의 정규화되거나 정규화되지 않은 이름입니다. 정규화된 개체 이름이 지정된 경우에만 따옴표가 필요합니다. 데이터베이스 이름을 포함하는 정규화된 개체 이름인 경우 데이터베이스 이름이 반드시 현재 데이터베이스의 이름이어야 합니다.
objname을 지정하지 않으면 전체 데이터베이스에 대한 결과가 반환됩니다.
objname은 **nvarchar(776)**이며 기본값은 NULL입니다.
[ @updateusage=] 'updateusage'
공간 사용 정보를 업데이트하려면 DBCC UPDATEUSAGE를 실행해야 함을 나타냅니다. objname을 지정하지 않으면 문이 전체 데이터베이스에서 실행됩니다. 지정하면 문이 objname에서 실행됩니다. 값은 true 또는 false입니다. updateusage는 **varchar(5)**이며 기본값은 false입니다.
반환 코드 값
0(성공) 또는 1(실패)
결과 집합
objname을 생략하면 다음 결과 집합이 반환되어 현재 데이터베이스 크기 정보를 제공합니다.
열 이름 | 데이터 형식 | 설명 |
---|---|---|
database_name |
nvarchar(128) |
현재 데이터베이스의 이름입니다. |
database_size |
varchar(18) |
현재 데이터베이스의 크기(메가바이트)입니다. database_size에는 데이터 및 로그 파일이 모두 포함됩니다. |
unallocated space |
varchar(18) |
데이터베이스 개체용으로 예약되지 않은 데이터베이스 공간입니다. |
열 이름 | 데이터 형식 | 설명 |
---|---|---|
reserved |
varchar(18) |
데이터베이스의 개체에 의해 할당된 총 공간입니다. |
data |
varchar(18) |
데이터가 사용하는 총 공간입니다. |
index_size |
varchar(18) |
인덱스가 사용하는 총 공간입니다. |
unused |
varchar(18) |
데이터베이스의 개체에 예약되었지만 아직 사용되지 않은 총 공간입니다. |
objname을 지정하면 지정된 개체에 대해 다음 결과 집합이 반환됩니다.
열 이름 | 데이터 형식 | 설명 |
---|---|---|
name |
nvarchar(128) |
공간 사용 정보가 필요한 개체의 이름입니다. 개체의 스키마 이름은 반환되지 앟습니다. 스키마 이름이 필요한 경우에는 sys.dm_db_partition_stats 또는 sys.dm_db_index_physical_stats 동적 관리 뷰를 사용하여 동일한 크기 정보를 확인할 수 있습니다. |
rows |
char(11) |
테이블에 있는 행 수입니다. 지정된 개체가 Service Broker 큐일 경우 이 열은 큐에 있는 메시지 수를 나타냅니다. |
reserved |
varchar(18) |
objname에 대해 예약된 총 공간입니다. |
data |
varchar(18) |
objname에서 데이터가 사용하는 총 공간입니다. |
index_size |
varchar(18) |
objname에서 인덱스가 사용하는 총 공간입니다. |
unused |
varchar(18) |
objname용으로 예약되었지만 아직 사용되지 않은 총 공간입니다. |
주의
database_size는 로그 파일의 크기를 포함하기 때문에 reserved + unallocated space의 합계보다 항상 큽니다. reserved 및 unallocated_space는 데이터 페이지만 고려하기 때문입니다.
XML 인덱스 및 전체 텍스트 인덱스에서 사용하는 페이지는 두 결과 집합 모두에 대해 index_size에 포함됩니다. objname이 지정된 경우 개체의 XML 인덱스 및 전체 텍스트 인덱스에서 사용하는 페이지도 전체 reserved 및 index_size 결과로 계산됩니다.
updateusage가 지정된 경우 SQL Server 2005 데이터베이스 엔진 은 데이터베이스에서 데이터 페이지를 검색하고 sys.allocation_units 및 sys.partitions 카탈로그 뷰를 각 테이블에서 사용하는 저장 공간에 맞춰 수정합니다. 수정해야 할 경우는 인덱스를 삭제한 후 테이블에 대한 공간 정보가 현재 정보와 다른 경우를 예로 들 수 있습니다. updateusage를 큰 테이블 또는 데이터베이스에서 실행하는 경우에는 시간이 걸릴 수 있습니다. 잘못된 값이 반환되었다는 의심이 들거나 이 프로세스가 데이터베이스의 다른 사용자 또는 프로세스에 역효과를 주지 않는 경우에만 updateusage를 사용하십시오. 원하는 경우에는 DBCC UPDATEUSAGE를 별도로 실행할 수 있습니다.
[!참고] 대형 인덱스를 삭제하거나 다시 작성할 때 또는 대형 테이블을 삭제하거나 자를 때 데이터베이스 엔진 은 트랜잭션이 커밋될 때까지 실제 페이지 할당 취소 및 관련 잠금을 연기합니다. 삭제 작업이 지연되어도 할당된 공간이 즉시 해제되지는 않습니다. 따라서 큰 개체를 삭제하거나 자른 직후에 sp_spaceused에서 반환하는 값에는 사용 가능한 실제 디스크 공간이 반영되지 않을 수도 있습니다. 지연된 할당에 대한 자세한 내용은 큰 개체 삭제 및 다시 작성을 참조하십시오.
사용 권한
sp_spaceused를 실행할 수 있는 사용 권한은 public 역할에 부여됩니다. db_owner 고정 데이터베이스 역할의 멤버만 @updateusage 매개 변수를 지정할 수 있습니다.
예
1. 테이블에 관한 디스크 공간 정보 표시
다음 예에서는 Vendor
테이블 및 해당 인덱스의 디스크 공간 정보를 알려 줍니다.
USE AdventureWorks;
GO
EXEC sp_spaceused N'Purchasing.Vendor';
GO
2. 데이터베이스에 관한 업데이트된 공간 정보 표시
다음 예에서는 현재 데이터베이스에서 사용한 공간을 요약하며 선택적 매개 변수 @updateusage를 사용하여 현재 값이 반환되도록 합니다.
USE AdventureWorks;
GO
EXEC sp_spaceused @updateusage = N'TRUE';
GO
참고 항목
참조
CREATE INDEX(Transact-SQL)
CREATE TABLE(Transact-SQL)
DBCC UPDATEUSAGE(Transact-SQL)
sys.allocation_units(Transact-SQL)
sys.indexes(Transact-SQL)
sys.index_columns(Transact SQL)
sys.objects(Transact-SQL)
sys.partitions(Transact-SQL)
시스템 저장 프로시저(Transact-SQL)