Created
October 2, 2014 19:59
-
-
Save cuchas/62dce45d504b649737dd to your computer and use it in GitHub Desktop.
sql-unused-indexes
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
-- WORK for SQL Server 2005 or later | |
-- Unused Index Script | |
-- Original Author: Pinal Dave (C) 2011 | |
-- http://blog.sqlauthority.com | |
SELECT TOP 30 | |
o.name AS ObjectName | |
, i.name AS IndexName | |
, i.index_id AS IndexID | |
,dm_ius.user_seeks AS UserSeek | |
,dm_ius.last_user_seek | |
,dm_ius.user_scans AS UserScans | |
,dm_ius.last_user_scan | |
, dm_ius.user_lookups AS UserLookups | |
, dm_ius.last_user_lookup | |
, dm_ius.user_updates AS UserUpdates | |
, p.TableRows | |
, | |
'DROP INDEX ' + QUOTENAME(i.name) | |
+ ' ON ' + QUOTENAME(s.name) + '.' + QUOTENAME(OBJECT_NAME(dm_ius.object_id)) as 'drop statement' | |
FROM sys.dm_db_index_usage_stats dm_ius | |
INNER JOIN sys.indexes i ON i.index_id = dm_ius.index_id AND dm_ius.object_id = i.object_id | |
INNER JOIN sys.objects o on dm_ius.object_id = o.object_id | |
INNER JOIN sys.schemas s on o.schema_id = s.schema_id | |
INNER JOIN (SELECT SUM(p.rows) TableRows, p.index_id, p.object_id | |
FROM sys.partitions p GROUP BY p.index_id, p.object_id) p | |
ON p.index_id = dm_ius.index_id AND dm_ius.object_id = p.object_id | |
WHERE OBJECTPROPERTY(dm_ius.object_id,'IsUserTable') = 1 | |
AND dm_ius.database_id = DB_ID() | |
AND i.type_desc = 'nonclustered' | |
AND i.is_primary_key = 0 | |
AND i.is_unique_constraint = 0 | |
--AND o.name = 'log_click' -- Looking for a specific table? Uncomment this line | |
ORDER BY (dm_ius.user_seeks + dm_ius.user_scans + dm_ius.user_lookups) ASC | |
GO |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment