sp_spaceused (Transact-SQL)
Выводит количество строк, зарезервированное место на диске и место на диске, которое используется таблицей, индексированным представлением или очередью компонента 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.
Если вычисляется используемое место на диске для базы данных или объекта с пространственным индексом, то столбцы, относящиеся к пространственным размерам, такие как database_size, reserved и index_size, содержат размер пространственного индекса.
Если указан аргумент updateusage, компонент SQL Server Database Engine просматривает страницы данных в базе данных и вносит все необходимые изменения в представления каталога sys.allocation_units и sys.partitions в отношении места для хранения каждой таблицы. Иногда возникают ситуации, например при удалении индекса, когда сведения о таблице могут устареть. Если указан аргумент updateusage, выполнение процедуры может занимать некоторое время при запуске в отношении больших таблиц или баз данных. Используйте аргумент updateusage только в том случае, если есть сомнения в достоверности возвращаемых значений и если выполнение процедуры не будет неблагоприятно влиять на других пользователей и процессы в базе данных. При необходимости инструкцию DBCC UPDATEUSAGE можно запускать отдельно.
Примечание |
---|
При удалении или перестроении больших индексов либо удалении или усечении больших таблиц компонент Database Engine откладывает фактическое освобождение страниц и связанных блокировок до момента фиксации транзакции. Отложенные операции удаления не освобождают выделенное место немедленно. Поэтому значения, возвращаемые процедурой sp_spaceused сразу после удаления или усечения большого объекта, могут не отражать реальный объем доступного места на диске. Дополнительные сведения об отложенном выделении объектов см. в разделе Удаление и повторная сборка больших объектов. |
Разрешения
Разрешение на выполнение процедуры sp_spaceused предоставлено роли public. Аргумент @updateusage указывается только членами предопределенной роли базы данных db_owner.
Примеры
А. Вывод сведений о месте на диске для таблицы
В следующем примере предоставляются сведения о месте на диске для таблицы Vendor и ее индексах.
USE AdventureWorks2008R2;
GO
EXEC sp_spaceused N'Purchasing.Vendor';
GO
Б. Вывод обновленных сведений о месте на диске для базы данных
В следующем примере приводятся итоговые сведения об использовании места на диске текущей базой данных с применением необязательного параметра @updateusage, чтобы получить достоверные текущие значения.
USE AdventureWorks2008R2;
GO
EXEC sp_spaceused @updateusage = N'TRUE';
GO
См. также