What is Proper Database Indexing?
Much like “Beauty is in the eye of the beholder,“ “Proper database indexing is in the eye of the workload.”
To understand how to properly index a database table, you must first know what the workload of the table is. For example, indexing every column of a table is probably a bad idea if all you are doing is inserting rows into a table. Indexing more than is necessary will result in an application that is slower than optimal and may result in an application that causes the database server to freeze under load. The other extreme is to not use any indexes or have any primary keys. While this typically allows for inserts to be performed as quickly as possible, it will result in other operations (select, delete, and update) being verrrrryyyyy slowwwwww. Lack of proper indexing may result in a database performing the dreaded table scan, which you want to avoid as much as possible. So, somewhere in between the two extremes is the proper set of indexes.
My ultimate suggestion is to use the proper set of indexes for your application by knowing what your application is doing with regards to the database and using the MS Sql Profiler and Index Tuning Wizard mentioned in a previous post.
Wally