sys.dm_os_buffer_descriptors (Transact-SQL)
Devuelve información acerca de todas las páginas de datos que están actualmente en el grupo de búferes de SQL Server. La salida de esta vista se puede utilizar para determinar la distribución de páginas de la base de datos en el grupo de búferes según la base de datos, el objeto o el tipo.
Cuando se lee una página de datos del disco, ésta se copia en el grupo de búferes de SQL Server y se almacena en caché para volver a utilizarla. Cada página de datos almacenada en caché tiene un descriptor de búfer. Los descriptores de búfer únicamente identifican cada página de datos que está almacenada actualmente en memoria caché en una instancia de SQL Server. sys.dm_os_buffer_descriptors devuelve páginas en memoria caché para todas las bases de datos de usuario y de sistema. Esto incluye las páginas que están asociadas a la base de datos Resource.
Nombre de columna |
Tipo de datos |
Descripción |
---|---|---|
database_id |
int |
Identificador de la base de datos asociada con la página en el grupo de búferes. Acepta valores NULL. |
file_id |
int |
Identificador del archivo que almacena la imagen permanente de la página. Acepta valores NULL. |
page_id |
int |
Identificador de la página en el archivo. Acepta valores NULL. |
page_level |
int |
Nivel de índice de la página. Acepta valores NULL. |
allocation_unit_id |
bigint |
Identificador de la unidad de asignación de la página. Este valor se puede usar para combinar sys.allocation_units. Acepta valores NULL. Nota sys.dm_os_buffer_descriptors puede mostrar valores inexistentes en allocation_unit_id para índices clúster creados en versiones de SQL Server anteriores a SQL Server 2005. |
page_type |
nvarchar(60) |
Tipo de la página, como: página de datos o página de índice. Acepta valores NULL. |
row_count |
int |
Número de filas de la página. Acepta valores NULL. |
free_space_in_bytes |
int |
Cantidad, en bytes, de espacio disponible en la página. Acepta valores NULL. |
is_modified |
bit |
1 = La página se ha modificado después de leerse en el disco. Acepta valores NULL. |
numa_node |
int |
Nodo de acceso no uniforme a memoria para el búfer. Acepta valores NULL. |
read_microsec |
bigint |
El tiempo real (en microsegundos) necesario para leer la página en el búfer. Este número se restablece cuando se reutiliza el búfer. Acepta valores NULL. |
Permisos
Necesita el permiso VIEW SERVER STATE en el servidor.
Comentarios
sys.dm_os_buffer_descriptors devuelve páginas que utiliza la base de datos Resource. sys.dm_os_buffer_descriptors no devuelve información sobre páginas descartadas ni disponibles, ni sobre páginas con errores durante su lectura.
De |
A |
En |
Relación |
---|---|---|---|
sys.dm_os_buffer_descriptors |
sys.databases |
database_id |
varios a uno |
sys.dm_os_buffer_descriptors |
<userdb>.sys.allocation_units |
allocation_unit_id |
varios a uno |
sys.dm_os_buffer_descriptors |
<userdb>.sys.database_files |
file_id |
varios a uno |
Ejemplos
A.Devolver el recuento de páginas almacenadas en caché de cada base de datos
En el ejemplo siguiente se devuelve el recuento de páginas cargadas para cada base de datos.
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;
B.Devolver el recuento de páginas almacenadas en caché para cada objeto de la base de datos actual
En el ejemplo siguiente se devuelve el recuento de páginas cargadas para cada objeto en la base de datos actual.
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;
Vea también
Referencia
sys.allocation_units (Transact-SQL)
Funciones y vistas de administración dinámica (Transact-SQL)
Vistas de administración dinámica relacionadas con el sistema operativo de SQL Server (Transact-SQL)