You are entering a very complex area of DBA work. When do I have to many indexes? and when can I use more coverng indexes?
If the table is written to a lot, you need to ensure that you do not have many indexes as this will degrade the insert/update/delete performance.
Also, you do not want over lapping indexes, as this will waste storage space.
What you do need to note though is that the order and columns selected for the index does matter.
I always use a telephone dictionary as an example.
If your index in the back was by firstname, lastname
, a serch for surname = Smith
would result in an entire index scan, if not a table scan.
So choosing your indexes is very important.
And also remember the use of included columns, this would greatly improve query performance where you find key lookups in the execution plans, but the trade off is that you use additional storage space.
Using an index advisor is great if you are starting to learn about query optimization, but I would recomend rather understanding the execution plans, and also narrowing down which type of queries you need the most for certain tables.