Déterminer la taille du disque disponible avec une requête SQL
-
19-09-2019 - |
Question
Je dois déterminer l'espace disponible sur le lecteur où vit ma base de données.
Je sais que sur la procédure de xp_fixeddrives
mais comment puis-je obtenir l'information pour le lecteur spécifique où réside ma base de données?
La solution
Quelque chose comme ça?
declare @DatabaseName sysname
set @DatabaseName = 'master'
declare @Drive table(DriveName char, FreeSpaceInMegabytes int)
insert @Drive execute xp_fixeddrives
select
mas.type_desc FileType,
mas.name FileName,
mas.physical_name PhysicalFileName,
mas.size * 8 / 1024 FileSizeInMegabytes,
drv.DriveName,
drv.FreeSpaceInMegabytes
from sys.master_files mas
left join @Drive drv on
left(mas.physical_name, 1) = drv.DriveName
where database_id = db_id(@DatabaseName)
Définir @DatabaseName
en conséquence.
Autres conseils
Vous ne l'avez pas mentionné votre version de SQL Server. À partir de SQL Server 2005, vous pouvez obtenir beaucoup d'informations de sys.database_files et les relier à la sortie de xp_fixeddrives.
SELECT Drive
, TotalSpaceGB
, FreeSpaceGB
, PctFree
, PctFreeExact
FROM
(SELECT DISTINCT
SUBSTRING(dovs.volume_mount_point, 1, 10) AS Drive
, CONVERT(INT, dovs.total_bytes / 1024.0 / 1024.0 / 1024.0) AS TotalSpaceGB
, CONVERT(INT, dovs.available_bytes / 1048576.0) / 1024 AS FreeSpaceGB
, CAST(ROUND(( CONVERT(FLOAT, dovs.available_bytes / 1048576.0) / CONVERT(FLOAT, dovs.total_bytes / 1024.0 /
1024.0) * 100 ), 2) AS NVARCHAR(50)) + '%' AS PctFree
, CONVERT(FLOAT, dovs.available_bytes / 1048576.0) / CONVERT(FLOAT, dovs.total_bytes / 1024.0 / 1024.0) * 100 AS PctFreeExact
FROM sys.master_files AS mf
CROSS APPLY sys.dm_os_volume_stats(mf.database_id, mf.file_id) AS dovs) AS DE
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow