sql >> Database >  >> RDS >> Sqlserver

Tabel- en indexgrootte in SQL Server

sp_spaceused geeft je de grootte van alle indexen samen.

Als u de grootte van elke index voor een tabel wilt, gebruikt u een van deze twee zoekopdrachten:

SELECT
    i.name                  AS IndexName,
    SUM(s.used_page_count) * 8   AS IndexSizeKB
FROM sys.dm_db_partition_stats  AS s 
JOIN sys.indexes                AS i
ON s.[object_id] = i.[object_id] AND s.index_id = i.index_id
WHERE s.[object_id] = object_id('dbo.TableName')
GROUP BY i.name
ORDER BY i.name

SELECT
    i.name              AS IndexName,
    SUM(page_count * 8) AS IndexSizeKB
FROM sys.dm_db_index_physical_stats(
    db_id(), object_id('dbo.TableName'), NULL, NULL, 'DETAILED') AS s
JOIN sys.indexes AS i
ON s.[object_id] = i.[object_id] AND s.index_id = i.index_id
GROUP BY i.name
ORDER BY i.name

De resultaten zijn meestal iets anders, maar binnen 1%.



  1. De beste efficiënte methode om MySQL vanuit PHP te verbinden?

  2. DROP alle externe sleutels in de MYSQL-database

  3. JDeveloper gebruiken met MySQL Database en Oracle Database op AWS RDS, deel 1

  4. innodb; meerdere gegevensmappen