Skip to content

Instantly share code, notes, and snippets.

@theuntitled
Created March 17, 2016 12:01
Show Gist options
  • Save theuntitled/e5f4b6f2c01db32d1d90 to your computer and use it in GitHub Desktop.
Save theuntitled/e5f4b6f2c01db32d1d90 to your computer and use it in GitHub Desktop.
Select the size and number of rows for each table of the database
SELECT
t.NAME AS TableName,
s.Name AS SchemaName,
p.rows AS RowCounts,
SUM(a.total_pages) * 8 AS TotalSpaceKB,
SUM(a.used_pages) * 8 AS UsedSpaceKB,
(SUM(a.total_pages) - SUM(a.used_pages)) * 8 AS UnusedSpaceKB
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
t.Name
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment