Herkese merhaba,
Bu yazıda SQL Server’da seçili veritabanındaki tabloların boyutlarına göre nasıl sıralanacağı hakkında bilgi vereceğim.
SQL Server’da bazı durumlarda (analiz, inceleme) tüm tabloların boyutlarına göre sıralanması istenebilir.
Aşağıdaki sorguyu kullanarak tabloları boyutlarına göre sıralayabilirsiniz.
SELECT t.name AS TableName,
s.name AS SchemaName,
p.rows AS RowCounts,
SUM(a.total_pages) * 8 AS TotalSpaceKB,
CAST(ROUND(((SUM(a.total_pages) * 8) / 1024.00), 2) AS NUMERIC(36, 2)) AS TotalSpaceMB,
SUM(a.used_pages) * 8 AS UsedSpaceKB,
CAST(ROUND(((SUM(a.used_pages) * 8) / 1024.00), 2) AS NUMERIC(36, 2)) AS UsedSpaceMB,
(SUM(a.total_pages) - SUM(a.used_pages)) * 8 AS UnusedSpaceKB,
CAST(ROUND(((SUM(a.total_pages) - SUM(a.used_pages)) * 8) / 1024.00, 2) AS NUMERIC(36, 2)) AS UnusedSpaceMB
FROM sys.tables t
INNER JOIN sys.indexes i
ON t.object_id = i.object_id
INNER JOIN sys.partitions p
ON i.object_id = p.object_id
AND i.index_id = p.index_id
INNER JOIN sys.allocation_units a
ON p.partition_id = a.container_id
LEFT OUTER JOIN sys.schemas s
ON t.schema_id = s.schema_id
WHERE t.name NOT LIKE 'dt%'
AND t.is_ms_shipped = 0
AND i.object_id > 255
GROUP BY t.name,
s.name,
p.rows
ORDER BY UnusedSpaceMB DESC;
Sorguyu çalıştırdınız zaman aşağıdaki gibi bir sonuç alacaksınız.
Ben bu sonucu AdventureWorks veritabanını kullanarak elde ettim. Sizler kendi veritabanlarınız üzerinde çalıştırabilirsiniz.
Herkese çalışma hayatında ve yaşamında başarılar kolaylıklar.