sys.dm_os_volume_stats (Transact-SQL)
Aplica-se a:SQL Server
Retorna informações sobre o volume do sistema operacional (diretório) no qual os bancos de dados e arquivos especificados são armazenados no SQL Server. Use esta função de gerenciamento dinâmico para verificar os atributos da unidade de disco físico ou retornar informações de espaço livre disponíveis sobre o diretório.
Transact-SQL convenções de sintaxe
Sintaxe
sys.dm_os_volume_stats (database_id , file_id)
Argumentos
database_id
ID da base de dados.
database_id é int, sem padrão. Não pode ser NULL
.
file_id
ID do ficheiro.
file_id é int, sem padrão. Não pode ser NULL
.
Tabela retornada
Coluna | Tipo de dados | Descrição |
---|---|---|
database_id |
int | ID da base de dados. Não anulável. |
file_id |
int | ID do ficheiro. Não anulável. |
volume_mount_point |
nvarchar(512) | Ponto de montagem no qual o volume está enraizado. Pode retornar uma cadeia de caracteres vazia. Retorna null no Linux. |
volume_id |
nvarchar(512) | ID do volume do sistema operacional. Pode retornar uma cadeia de caracteres vazia. Retorna null no Linux. |
logical_volume_name |
nvarchar(512) | Nome do volume lógico. Pode retornar uma cadeia de caracteres vazia. Retorna null no Linux. |
file_system_type |
nvarchar(512) | Tipo de volume do sistema de arquivos (por exemplo, NTFS, FAT, RAW). Pode retornar uma cadeia de caracteres vazia. Retorna null no Linux. |
total_bytes |
bigint | Tamanho total em bytes do volume. Não anulável. |
available_bytes |
bigint | Espaço livre disponível no volume. Não anulável. |
supports_compression |
minúsculo | Indica se o volume suporta a compactação do sistema operacional. Não anulável no Windows e retorna null no Linux. |
supports_alternate_streams |
minúsculo | Indica se o volume suporta fluxos alternativos. Não anulável no Windows e retorna null no Linux. |
supports_sparse_files |
minúsculo | Indica se o volume suporta arquivos esparsos. Não anulável no Windows e retorna null no Linux. |
is_read_only |
minúsculo | Indica se o volume está atualmente marcado como somente leitura. Não anulável. |
is_compressed |
minúsculo | Indica se esse volume está compactado no momento. Não anulável no Windows e retorna null no Linux. |
incurs_seek_penalty |
minúsculo | Indica o tipo de armazenamento que suporta este volume. Os valores possíveis são:0 : Nenhuma penalidade de busca neste volume, normalmente quando o dispositivo de armazenamento é PMM ou SSD1 : Procurar penalidade sobre este volume, normalmente quando o dispositivo de armazenamento é HDD2 : O tipo de armazenamento não pode ser determinado quando o volume está em um caminho UNC ou compartilhamentos montadosNULL : O tipo de armazenamento não pode ser determinado no sistema operacional LinuxAplica-se a: SQL Server 2019 (15.x) e versões posteriores |
Permissões
O SQL Server 2019 (15.x) e versões anteriores exigem permissão de VIEW SERVER STATE
no servidor.
O SQL Server 2022 (16.x) e versões posteriores exigem VIEW SERVER PERFORMANCE STATE
permissão no servidor.
Exemplos
Um. Retornar espaço total e espaço disponível para todos os arquivos de banco de dados
O exemplo a seguir retorna o espaço total e o espaço disponível (em bytes) para todos os arquivos de banco de dados na instância do SQL Server.
SELECT f.database_id,
f.file_id,
volume_mount_point,
total_bytes,
available_bytes
FROM sys.master_files AS f
CROSS APPLY sys.dm_os_volume_stats(f.database_id, f.file_id);
B. Retornar espaço total e espaço disponível para o banco de dados atual
O exemplo a seguir retorna o espaço total e o espaço disponível (em bytes) para os arquivos de banco de dados no banco de dados atual.
SELECT database_id,
f.file_id,
volume_mount_point,
total_bytes,
available_bytes
FROM sys.database_files AS f
CROSS APPLY sys.dm_os_volume_stats(DB_ID(), f.file_id);