Compartilhar via


sys.dm_os_buffer_descriptors (Transact-SQL)

Status do tópico: algumas informações neste tópico são de pré-lançamento e estão sujeitas a mudanças em versões futuras. As informações de pré-lançamento descrevem novos recursos ou alterações em recursos existentes no Microsoft SQL Server 2014.

Retorna informações sobre todas as páginas de dados atualmente no pool de buffer do SQL Server. A saída dessa exibição pode ser usada para determinar a distribuição de páginas de bancos de dados no pool de buffer de acordo com o banco de dados, objeto ou tipo. No SQL Server 2014, essa exibição de gerenciamento dinâmico também retorna informações sobre as páginas de dados no arquivo de extensão do pool de buffers. Para obter mais informações, consulte Extensão do pool de buffers.

Quando uma página de dados é lida a partir do disco, a página é copiada para o pool de buffer do SQL Server e armazenada em cache para reutilização. Cada página de dados tem um descritor de buffer. Descritores de buffer que identificam exclusivamente cada página de dados armazenada em cache no momento em uma instância do SQL Server. sys.dm_os_buffer_descriptors retorna páginas armazenadas em cache para todos os usuários e bancos de dados do sistema. Isso inclui páginas que estão associadas ao banco de dados Resource.

Aplica-se a: SQL Server (do SQL Server 2008 à versão atual).

Nome da coluna

Tipo de dados

Descrição

database_id

int

Identificação do banco de dados associada à página no pool de buffer. Permite valor nulo.

file_id

int

Identificação do arquivo que armazena a imagem persistida da página. Permite valor nulo.

page_id

int

Identificação da página no arquivo. Permite valor nulo.

page_level

int

Nível de índice da página. Permite valor nulo.

allocation_unit_id

bigint

ID da unidade de alocação da página. Esse valor pode ser usado para unir sys.allocation_units. Permite valor nulo.

page_type

nvarchar(60)

Tipo da página, como: página de Dados ou página de Índice. Permite valor nulo.

row_count

int

Número de linhas na página. Permite valor nulo.

free_space_in_bytes

int

Quantidade de espaço livre disponível, em bytes, na página. Permite valor nulo.

is_modified

bit

1 = A página foi modificada depois de lida no disco. Permite valor nulo.

numa_node

int

Nó de acesso à memória não uniforme do buffer. Permite valor nulo.

read_microsec

bigint

A hora real (em microssegundos) necessária para ler a página no buffer. Este número é redefinido quando o buffer é reutilizado. Permite valor nulo.

Permissões

Requer a permissão VIEW SERVER STATE no servidor.

Comentários

sys.dm_os_buffer_descriptors retorna páginas que estão sendo usadas pelo banco de dados Resource. sys.dm_os_buffer_descriptors não retorna informações sobre páginas livres ou roubadas ou sobre páginas que apresentaram erros quando foram lidas.

De

Para

Em

Relação

sys.dm_os_buffer_descriptors

sys.databases

database_id

muitos para um

sys.dm_os_buffer_descriptors

<userdb>.sys.allocation_units

allocation_unit_id

muitos para um

sys.dm_os_buffer_descriptors

<userdb>.sys.database_files

file_id

muitos para um

sys.dm_os_buffer_descriptors

sys.dm_os_buffer_pool_extension_configuration

file_id

muitos para um

Exemplos

A.Retornando a contagem de páginas armazenadas em cache para cada banco de dados

O exemplo a seguir retorna a contagem de páginas carregadas em cada banco de dados.

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.Retorno de contagem de páginas para cada objeto no banco de dados atual

O exemplo a seguir retorna a contagem de páginas carregada em cada objeto no banco de dados atual.

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 também

Referência

sys.allocation_units (Transact-SQL)

Exibições e funções de gerenciamento dinâmico (Transact-SQL)

Exibições de gerenciamento dinâmico relacionadas ao sistema operacional do SQL Server (Transact-SQL)

sys.dm_os_buffer_pool_extension_configuration (Transact-SQL)

Conceitos

Banco de dados de recursos