Exibições de gerenciamento dinâmico do sistema

Aplica-se a:SQL ServerBanco de Dados SQL do AzureInstância Gerenciada de SQL do AzureAzure Synapse AnalyticsPDW (Analytics Platform System)Ponto de extremidade de SQL no Microsoft FabricWarehouse no Microsoft Fabric

As exibições de gerenciamento dinâmico (DMVs) e as funções de gerenciamento dinâmico (DMFs) retornam informações de estado do servidor que podem ser usadas para monitorar a integridade de uma instância de servidor, diagnosticar problemas e ajustar o desempenho.

Importante

Elas retornam dados de estado internos específicos de implementação. Seus esquemas e os dados que eles retornam podem ser alterados em versões futuras do SQL Server. Por isso, as exibições e funções de gerenciamento dinâmico, em versões futuras, podem não ser compatíveis com as exibições e funções de gerenciamento dinâmico nessa versão. Por exemplo, em versões futuras do SQL Server, a Microsoft pode aumentar a definição de qualquer modo de exibição de gerenciamento dinâmico adicionando colunas ao final da lista de colunas. Não é recomendável o uso da sintaxe SELECT * FROM dynamic_management_view_name no código de produção, pois o número de colunas retornado pode mudar e quebrar seu aplicativo.

Há dois tipos de exibições e funções de gerenciamento dinâmico:

  • Exibições e funções de gerenciamento dinâmico de escopo de servidor. Requerem a permissão VIEW SERVER STATE no servidor. Para o SQL Server 2022 e posterior, VIEW SERVER PERFORMANCE STATE é necessário ou VIEW SERVER SECURITY STATE é necessário para alguns DMVs relacionados à segurança.

  • Exibições e funções de gerenciamento dinâmico de escopo de banco de dados. Requerem permissão VIEW DATABASE STATE no banco de dados. Para o SQL Server 2022 e posterior, VIEW DATABASE PERFORMANCE STATE é necessário ou VIEW DATABASE SECURITY STATE é necessário para alguns DMVs relacionados à segurança.

Consultar exibições de gerenciamento dinâmico

As exibições de gerenciamento dinâmico podem ser referenciadas em instruções Transact-SQL usando nomes de duas, três ou quatro partes. As funções de gerenciamento dinâmico, por outro lado, podem ser referenciadas em instruções Transact-SQL usando nomes de duas ou três partes. As exibições e funções de gerenciamento dinâmico não podem ser referenciadas em instruções Transact-SQL usando nomes de uma parte.

Todas as exibições e funções de gerenciamento dinâmico estão no esquema sys e seguem a convenção de nomenclatura dm_*. Quando você usa uma exibição ou função de gerenciamento dinâmico, é preciso prefixar o nome da exibição ou função usando o esquema sys. Por exemplo, para consultar a exibição de gerenciamento dinâmico dm_os_wait_stats, execute a seguinte consulta:

SELECT wait_type, wait_time_ms
FROM sys.dm_os_wait_stats;

Permissões necessárias

A consulta de uma exibição ou função de gerenciamento dinâmico requer a permissão SELECT no objeto e a permissão VIEW SERVER STATE ou VIEW DATABASE STATE. Isso permite restringir seletivamente o acesso de um usuário ou logon a exibições e funções de gerenciamento dinâmico. Para fazer isso, primeiro crie o usuário e, em master seguida, negue a permissão SELECT do usuário nas exibições ou funções de gerenciamento dinâmico que você não deseja que ele acesse. Depois disso, o usuário não pode selecionar entre essas exibições ou funções de gerenciamento dinâmico, independentemente do contexto do banco de dados do usuário.

Observação

Como DENY prevalece, se um usuário tiver recebido permissões VIEW SERVER STATE, mas não a permissão VIEW DATABASE STATE, ele poderá verificar as informações de servidor, mas não as de banco de dados.

Nesta seção

As exibições e as funções de gerenciamento dinâmico foram organizadas nas seguintes categorias.