Compartir a través de


sys.dm_os_buffer_descriptors (Transact-SQL)

Se aplica a: SQL Server Azure SQL Database Azure SQL Instancia administrada Azure Synapse Analytics Analytics Platform System (PDW)

Devuelve información sobre todas las páginas de datos que se encuentran 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. En SQL Server, esta vista de administración dinámica también devuelve información sobre las páginas de datos del archivo de extensión del grupo de búferes. Para obtener más información, consulte Extensión del grupo de búferes.

Cuando se lee una página de datos del disco, la página se copia en el grupo de búferes de SQL Server y se almacena en caché para su reutilización. Cada página de datos almacenada en caché tiene un descriptor de búfer. Los descriptores de búfer identifican de forma única cada página de datos que se almacena actualmente en 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.

Nota:

Para llamarlo desde Azure Synapse Analytics o Analytics Platform System (PDW), use el nombre sys.dm_pdw_nodes_os_buffer_descriptors. El grupo de SQL sin servidor no admite esta sintaxis en Azure Synapse Analytics.

Nombre de la 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.

En Azure SQL Database, los valores son únicos dentro de una base de datos única o un grupo elástico, pero no dentro de un servidor lógico.
file_id int Identificador del archivo que almacena la imagen permanente de la página. Acepta valores NULL.
page_id int Id. de la página dentro del 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 utilizar para combinar sys.allocation_units. Acepta valores NULL.
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.
is_in_bpool_extension bit 1 = La página está en la extensión del grupo de búferes. Acepta valores NULL.
pdw_node_id int Se aplica a: Azure Synapse Analytics, Sistema de la plataforma de análisis (PDW)

Identificador del nodo en el que se encuentra esta distribución.

Permisos

En SQL Server y SQL Managed Instance, requiere el permiso VIEW SERVER STATE.

En los objetivos de servicio de SQL Database Basic, S0 y S1, y para las bases de datos de grupos elásticos, se requiere la cuenta de administrador del servidor, la cuenta de administrador de Microsoft Entra o la pertenencia al rol de ##MS_ServerStateReader## servidor. En el resto de objetivos del servicio de SQL Database, se requiere el permiso VIEW DATABASE STATE en la base de datos o la pertenencia en el rol del servidor ##MS_ServerStateReader##.

Permisos para SQL Server 2022 y versiones posteriores

Requiere el permiso VER ESTADO DE RENDIMIENTO DEL SERVIDOR en el servidor.

Comentarios

sys.dm_os_buffer_descriptors devuelve páginas que usa la base de datos de recursos. sys.dm_os_buffer_descriptors no devuelve información sobre páginas gratuitas o robadas, ni sobre las páginas que tenían errores cuando se leían.

De En Activado 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
sys.dm_os_buffer_descriptors sys.dm_os_buffer_pool_extension_configuration 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;  

Consulte también

sys.allocation_units (Transact-SQL)

Vistas de administración dinámica relacionadas con el sistema operativo de SQL Server (Transact-SQL)
Base de datos Resource
sys.dm_os_buffer_pool_extension_configuration (Transact-SQL)