Dans mssql2005, lorsque je veux obtenir la taille d'une table en Mo, j'utilise EXEC sp_spaceused 'table'.
Existe-t-il un moyen d'obtenir l'espace utilisé par une table particulière dans SQL Azure à l'aide d'une requête ou d'une API ?
Dans mssql2005, lorsque je veux obtenir la taille d'une table en Mo, j'utilise EXEC sp_spaceused 'table'.
Existe-t-il un moyen d'obtenir l'espace utilisé par une table particulière dans SQL Azure à l'aide d'une requête ou d'une API ?
De Ryan Dunn http://dunnry.com/blog/CalculatingTheSizeOfYourSQLAzureDatabase.aspx
select
sum(reserved_page_count) * 8.0 / 1024 [SizeInMB]
from
sys.dm_db_partition_stats
GO
select
sys.objects.name, sum(reserved_page_count) * 8.0 / 1024 [SizeInMB]
from
sys.dm_db_partition_stats, sys.objects
where
sys.dm_db_partition_stats.object_id = sys.objects.object_id
group by sys.objects.name
order by sum(reserved_page_count) DESC
La première vous donnera la taille de votre base de données en Mo et la seconde fera de même, mais en la ventilant pour chaque objet de votre base de données, du plus grand au plus petit.
Voici une requête qui vous donnera, par table, la taille totale, le nombre de lignes et le nombre d'octets par ligne :
select
o.name,
max(s.row_count) AS 'Rows',
sum(s.reserved_page_count) * 8.0 / (1024 * 1024) as 'GB',
(8 * 1024 * sum(s.reserved_page_count)) / (max(s.row_count)) as 'Bytes/Row'
from sys.dm_db_partition_stats s, sys.objects o
where o.object_id = s.object_id
group by o.name
having max(s.row_count) > 0
order by GB desc
Et voici une requête qui est la même que ci-dessus mais qui la décompose par index :
select
o.Name,
i.Name,
max(s.row_count) AS 'Rows',
sum(s.reserved_page_count) * 8.0 / (1024 * 1024) as 'GB',
(8 * 1024* sum(s.reserved_page_count)) / max(s.row_count) as 'Bytes/Row'
from
sys.dm_db_partition_stats s,
sys.indexes i,
sys.objects o
where
s.object_id = i.object_id
and s.index_id = i.index_id
and s.index_id >0
and i.object_id = o.object_id
group by i.Name, o.Name
having SUM(s.row_count) > 0
order by GB desc
De cette façon, vous pouvez avoir le plus gros sur le dessus :
SELECT sys.objects.name,
SUM(row_count) AS 'Row Count',
SUM(reserved_page_count) * 8.0 / 1024 AS 'Table Size (MB)'
FROM sys.dm_db_partition_stats, sys.objects
WHERE sys.dm_db_partition_stats.object_id = sys.objects.object_id
GROUP BY sys.objects.name
ORDER BY [Table Size (MB)] DESC
Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.