Collections:
What Is Index Fragmentation in SQL Server
What Is Index Fragmentation in SQL Server?
✍: FYIcenter.com
Index fragmentation is a phenomena where index contents are no longer stored continuously in the storage. When index contents become scattered in the storage, fragmented, performance on index will degrade.
If you want to see the fragmentation level of an index, you can use the system function called sys.dm_db_index_physical_stats() in the following format:
SELECT * FROM sys.dm_db_index_physical_stats( database_id, table_id, index_id, DEFAULT, DEFAULT )
The tutorial exercise below shows you how to view the fragmentation level of all indexes on table "fyi_links_indexed":
USE FyiCenterData
GO
SELECT COUNT(*) FROM fyi_links_indexed;
GO
100000
SELECT i.index_id, i.name, s.avg_fragmentation_in_percent
FROM sys.dm_db_index_physical_stats (
DB_ID(N'FyiCenterData'),
OBJECT_ID(N'fyi_links_indexed'),
DEFAULT, DEFAULT, DEFAULT) s, sys.indexes i
WHERE s.object_id = i.object_id
AND s.index_id = i.index_id;
GO
index_id name avg_fragmentation_in_percent
0 NULL 0.574712643678161
2 fyi_links_url 0
3 fyi_links_counts 0
Since there is no clustered index (index_id=0) on this table, the first row in the return is just a place holder.
The other two rows show that "fyi_links_url" and "fyi_links_counts" have zero fragmentation, since they were created not long ago.
⇒ What Causes Index Fragmentation in SQL Server
⇐ CREATE INDEX - Impact on Other User Sessions in SQL Server
2016-11-08, 2555🔥, 0💬
Popular Posts:
What Happens to Your Transactions When ERROR 1205 Occurred in MySQL? If your transaction receives th...
How To Format Time Zone in +/-hh:mm Format in SQL Server Transact-SQL? From the previous tutorial, y...
How To Query Tables and Loop through the Returning Rows in MySQL? The best way to query tables and l...
How To List All Login Names on the Server in SQL Server? If you want to see a list of all login name...
How To Generate Random Numbers with the RAND() Function in SQL Server Transact-SQL? Random numbers a...