sys.dm_os_buffer_descriptors (Transact-SQL)
Возвращает сведения обо всех страницах данных, расположенных в данный момент в буферном пуле SQL Server. Это представление может использоваться, чтобы определить распределение страниц баз данных в буферном пуле в соответствии с базой данных, объектом или типом.
При считывании страницы данных с диска она копируется в буферный пул SQL Server и кэшируется для повторного использования. Каждая страница данных в кэше имеет один дескриптор буфера. Дескрипторы буфера уникально идентифицируют каждую страницу данных, кэшируемую в данный момент в экземпляре SQL Server. Представление sys.dm_os_buffer_descriptors возвращает страницы в кэше для всех баз данных пользователя и системных баз данных. В их число входят страницы, связанные с базой данных Resource.
Имя столбца |
Тип данных |
Описание |
---|---|---|
database_id |
int |
Идентификатор базы данных, связанный со страницей в буферном пуле. Допускает значение NULL. |
file_id |
int |
Идентификатор файла, хранящего постоянный образ страницы. Допускает значение NULL. |
page_id |
int |
Идентификатор страницы в файле. Допускает значение NULL. |
page_level |
int |
Индексный уровень страницы. Допускает значение NULL. |
allocation_unit_id |
bigint |
Идентификатор единицы распределения страницы. Это значение может быть использовано для соединения sys.allocation_units. Допускает значение NULL. Примечание. В представлении sys.dm_os_buffer_descriptors в столбце allocation_unit_id могут отображаться несуществующие значения для тех кластеризованных индексов, которые были созданы в версиях SQL Server, более ранних чем SQL Server 2005. |
page_type |
nvarchar(60) |
Тип страницы, например: страница данных или страница индекса. Допускает значение NULL. Дополнительные сведения см. в разделе Страницы и экстенты. |
row_count |
int |
Количество строк на странице. Допускает значение NULL. |
free_space_in_bytes |
int |
Объем доступного свободного места, в байтах, на странице. Допускает значение NULL. |
is_modified |
bit |
1 = страница была изменена после того, как она была считана с диска. Допускает значение NULL. |
numa_mode |
int |
Узел с неоднородным доступом к памяти для буфера. |
Разрешения
Требуется разрешение VIEW SERVER STATE на сервере.
Замечания
Представление sys.dm_os_buffer_descriptors возвращает страницы, которые использует база данных resource. Оно не возвращает сведения о свободных или заимствованных страницах, а также о страницах, при чтении которых возникали ошибки.
От |
В |
Вкл. |
Связь |
---|---|---|---|
sys.dm_os_buffer_descriptors |
sys.databases |
database_id |
«многие к одному» |
sys.dm_os_buffer_descriptors |
<userdb>.sys.allocation_units |
allocation_unit_id |
«многие к одному» |
sys.dm_os_buffer_descriptors |
<userdb>.sys.database_files |
file_id |
«многие к одному» |
Примеры
А. Получение количества страниц в кэше для каждой базы данных
Следующий пример возвращает количество страниц в кэше, загруженных для каждой базы данных.
SELECT count(*)AS cached_pages_count
,CASE database_id
WHEN 32767 THEN 'ResourceDb'
ELSE db_name(database_id)
END AS Database_name
FROM sys.dm_os_buffer_descriptors
GROUP BY db_name(database_id) ,database_id
ORDER BY cached_pages_count DESC;
Б. Получение количества страниц в кэше для каждого объекта в текущей базе данных
Следующий пример возвращает количество страниц в кэше, загруженных для каждого объекта в текущей базе данных.
SELECT count(*)AS cached_pages_count
,name ,index_id
FROM sys.dm_os_buffer_descriptors AS bd
INNER JOIN
(
SELECT object_name(object_id) AS name
,index_id ,allocation_unit_id
FROM sys.allocation_units AS au
INNER JOIN sys.partitions AS p
ON au.container_id = p.hobt_id
AND (au.type = 1 OR au.type = 3)
UNION ALL
SELECT object_name(object_id) AS name
,index_id, allocation_unit_id
FROM sys.allocation_units AS au
INNER JOIN sys.partitions AS p
ON au.container_id = p.partition_id
AND au.type = 2
) AS obj
ON bd.allocation_unit_id = obj.allocation_unit_id
WHERE database_id = db_id()
GROUP BY name, index_id
ORDER BY cached_pages_count DESC;