Thursday, October 11, 2012

Identify Numbers of Non Clustered Index on Tables for Entire Database

Here is the script which will give you numbers of non clustered indexes on any table in entire database.
SELECT COUNT(i.TYPE) NoOfIndex,[schema_name] = s.name, table_name = o.nameFROM sys.indexes iINNER JOIN sys.objects o ON i.[object_id] = o.[object_id]INNER JOIN sys.schemas s ON o.[schema_id] = s.[schema_id]WHERE o.TYPE IN ('U')
AND
i.TYPE = 2GROUP BY s.name, o.nameORDER BY schema_name, table_name
Here is the small story behind why this script was needed.
I recently went to meet my friend in his office and he introduced me to his colleague in office as someone who is an expert in SQL Server Indexing. I politely said I am yet learning about Indexing and have a long way to go. My friend’s colleague right away said – he had a suggestion for me with related to Index. According to him he was looking for a script which will count all the non clustered on all the tables in the database and he was not able to find that on SQLAuthority.com.
I was a bit surprised as I really do not remember all the details about what I have written so far. I quickly pull up my phone and tried to look for the script on my custom search engine and he was correct. I never wrote a script which will count all the non clustered indexes on tables in the whole database. Excessive indexing is not recommended in general. If you have too many indexes it will definitely negatively affect your performance. The above query will quickly give you details of numbers of indexes on tables on your entire database. You can quickly glance and use the numbers as reference.
Please note that the number of the index is not a indication of bad indexes. There is a lot of wisdom I can write here but that is not the scope of this blog post. There are many different rules with Indexes and many different scenarios. For example – a table which is heap (no clustered index) is often not recommended on OLTP workload (here is the blog post to identify them), drop unused indexes with careful observation (here is the script for it), identify missing indexes and after careful testing add them (here is the script for it). Even though I have given few links here it is just the tip of the iceberg. If you follow only above four advices your ship may still sink. Those who wants to learn the subject in depth can watch the videos here after logging in.
Note: You change where condition type to 6 for nonclustered column store index.
Reference: Pinal Dave (http://blog.sqlauthority.com)

No comments:

Post a Comment